【JDBC】数据库连接的艺术:深入解析数据库连接池、Apache-DBUtils与BasicDAO

在这里插入图片描述

文章目录

    • 前言
    • 🌍 一.连接池
      • ❄️1. 传统获取Conntion问题分析
      • ❄️2. 数据库连接池
      • ❄️3.连接池之C3P0技术
        • 🍁3.1关键特性
        • 🍁3.2配置选项
        • 🍁3.3使用示例
      • ❄️4. 连接池之Druid技术
        • 🍁 4.1主要特性
        • 🍁 4.2 配置选项
        • 🍁 4.3 使用示例
    • 🌍 二.Apache-DBUtil
        • ❄️1. 关键特性
        • ❄️2. 主要类和方法
        • ❄️3. 使用示例
    • 🌍 三.BasicDAO
      • ❄️1. 引入
      • ❄️2. `BasicDAO` 类通常包含以下功能:
      • ❄️3. 以下是如何使用 `BasicDAO` 的示例:


🙋‍♂️ 作者:@whisperrr.🙋‍♂️

👀 专栏:JDBC 👀

🎉 其他专栏:零基础学Mysql 🎉

💥 标题:探索JDBC:Java数据库连接的艺术与魅力💥

❣️ 寄语:比较是偷走幸福的小偷❣️

前言

在当今信息时代的浪潮中,数据库作为信息存储和处理的核心,其重要性不言而喻。作为一名普通的软件开发者,我在数据库连接与操作的道路上摸索前行,积累了一些实践经验。在此,与大家分享关于数据库连接池、Apache-DBUtils和BasicDAO这三个技术的一些心得和体会。本文旨在抛砖引玉,希望能够为同行们在优化数据库操作、提高系统性能的征途上提供一点参考和帮助。让我们一起学习,共同进步。

🌍 一.连接池

在学习一个新技术的时候,我们先来看看传统的方式有哪些问题,新技术又能解决什么样的问题,通过什么方式解决问题.

❄️1. 传统获取Conntion问题分析

  1. 传统的JDBC数据库连接使用DriverManager来获取,每次向数据库建立连接的时候都要将 Connection 加载的内存中,再验证 IP 地址,用户名和密码,频繁的进行数据库的连接将要占用很多的系统资源,任意造成服务器崩溃.
  2. 每一次数据库连接,都要及时断开,如果程序出现异常而未能及时关闭,将导致数据库内存泄漏,最终将导致重启数据库
  3. 传统的获取连接的方式,不能控制连接的数量,如果连接过多,也可能导致数据库的内存泄漏

感情的自然流露,我们引出数据库连接池。

❄️2. 数据库连接池

数据库连接池(Database Connection Pool)是一种用于提高数据库操作性能和资源管理效率的技术。可以很好的解决上面的传统方式带来的问题.

2.1 数据库连接池的基本原理如下:

  1. 初始化: 在系统启动时,创建一定数量的数据库连接,并将这些连接放入连接池中。
  2. 使用: 当用户请求一个数据库连接时,连接池会提供一个空闲的连接。如果连接池中没有空闲连接,则会根据最大连接数限制决定是否创建新的连接。
  3. 释放: 当用户完成数据库操作后,不会直接关闭数据库连接,而是将连接返回给连接池,以便其他请求复用。
  4. 管理: 连接池负责维护连接的状态,如定期检查连接的有效性,根据需要创建或销毁连接,保证连接池中的连接数量在一个合理的范围内。

2.2 数据库连接池的优点包括:

  • 提高性能: 通过复用连接减少建立和关闭连接的次数,显著提高系统性能。
  • 资源利用: 有效管理数据库连接,避免连接泄漏,节省系统资源。
  • 响应速度: 减少等待建立连接的时间,提高系统的响应速度。
  • 可配置性: 可以根据系统负载动态调整连接池的大小,适应不同的应用场景。

2.3 数据库连接池的技术包括:JDBC的数据库连接池使用javax.sql.DataSource来表示,DataSource只是一个接口,该接口通常由第三方提供实现[提供.jar]

  • C3PO数据库连接池,速度相对较慢,稳定性不错(hibernate,spring)
  • DBCP数据库连接池,速度相对c3p0较快,但不稳定
  • Proxool数据库连接池,有监控连接池状态的功能,稳定性较c3p0差一点
  • BoneCP数据库连接池,速度快
  • Druid(德鲁伊)是阿里提供的数据库连接池,集DBCP、C3PO、Proxool优点于一身的数据库连接池

❄️3.连接池之C3P0技术

c3p0 是一个 Java 编程语言中的数据库连接池库,它实现了数据源和 JNDI 适配器,用于提高数据库操作的效率和性能。c3p0 旨在提供一个高效、可靠的解决方案,用于管理数据库连接,减少创建和销毁连接的开销。
以下是 c3p0 的一些关键特性和配置选项:

🍁3.1关键特性
  1. 自动连接池管理: c3p0 能够自动管理数据库连接池,无需手动干预。
  2. 配置灵活: 提供了丰富的配置选项,可以通过 XML 文件、属性文件或直接在代码中进行配置。
  3. 支持多种数据库: c3p0 支持多种关系型数据库,如 MySQL、PostgreSQL、Oracle、SQL Server 等。
  4. 数据源和 JNDI 支持: c3p0 可以配置为数据源,并且可以与 JNDI 一起使用,便于在应用服务器环境中集成。
  5. 扩展性: c3p0 设计上考虑了扩展性,允许开发者根据需要定制连接池的行为。
🍁3.2配置选项

以下是一些常用的 c3p0 配置参数:

  • initialPoolSize: 初始化时创建的连接数。
  • maxPoolSize: 连接池中保留的最大连接数。
  • minPoolSize: 连接池中保留的最小连接数。
  • maxIdleTime: 连接的最大空闲时间,超过这个时间未使用的连接将被关闭。
  • acquireIncrement: 当连接池中的连接耗尽时,一次性创建的连接数。
  • idleConnectionTestPeriod: 空闲连接测试周期,用于验证空闲连接是否仍然有效。
  • checkoutTimeout: 当没有可用连接时,从连接池中获取连接的最大等待时间。
  • maxStatements: 缓存的最大 SQL 语句数。
  • maxStatementsPerConnection: 每个连接可以缓存的最大 SQL 语句数。
🍁3.3使用示例

以下是一个简单的 c3p0 配置和使用示例:

import com.mchange.v2.c3p0.ComboPooledDataSource;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;
public class C3P0Example {private static DataSource dataSource;static {ComboPooledDataSource cpds = new ComboPooledDataSource();cpds.setJdbcUrl("jdbc:mysql://localhost:3306/mydb");cpds.setUser("username");cpds.setPassword("password");cpds.setInitialPoolSize(5);cpds.setMaxPoolSize(20);// 其他配置...dataSource = cpds;}public static Connection getConnection() throws SQLException {return dataSource.getConnection();}public static void main(String[] args) {try (Connection conn = getConnection()) {// 使用连接进行数据库操作} catch (SQLException e) {e.printStackTrace();}}
}

在使用 c3p0 时,建议仔细阅读官方文档,并根据实际应用场景调整配置参数,以达到最佳性能。随着技术的发展,新的连接池技术(如 HikariCP)提供了更好的性能和更简单的配置,因此在选择连接池时,可以考虑比较不同库的性能和特性。

❄️4. 连接池之Druid技术

Druid 是一个用于数据库连接池和SQL监控的Java开源库,由阿里巴巴开源。它不仅提供了数据库连接池的功能,还包含了许多其他特性,如数据库加密、SQL执行日志、PSCache、慢SQL记录、SQL注入攻击防护等。Druid 广泛应用于各种需要数据库操作的Java应用程序中,特别是在大数据和高并发的场景下。
以下是 Druid 的一些主要特性和优势:

🍁 4.1主要特性
  1. 强大的连接池管理: Druid 提供了高效的连接池管理,支持多种数据库,并且能够处理大量并发连接。
  2. 监控功能: Druid 能够监控数据库访问性能,包括执行时间、并发数、慢查询等,有助于优化数据库性能。
  3. SQL防火墙: Druid 可以防止SQL注入攻击,确保数据库的安全性。
  4. 数据库加密: 支持对数据库密码进行加密,提高安全性。
  5. 多种配置方式: Druid 支持多种配置方式,包括XML、properties文件、编程方式等。
  6. 扩展性: Druid 设计灵活,可以通过编写插件来扩展其功能。
🍁 4.2 配置选项

Druid 的配置选项非常丰富,以下是一些常用的配置参数:

  • initialSize: 初始化时建立物理连接的个数。
  • minIdle: 最小连接池数量。
  • maxActive 最大连接池数量。
  • maxWait: 获取连接时最大等待时间,单位毫秒。
  • timeBetweenEvictionRunsMillis 间隔多久进行一次检测,检测需要关闭的空闲连接。
  • minEvictableIdleTimeMillis: 连接在池中最小生存的时间。
  • validationQuery: 用来检测连接是否有效的SQL语句。
  • testWhileIdle: 建议配置为true,不影响性能,并且保证安全性。
  • estOnBorrow: 申请连接时执行validationQuery检测连接是否有效。
  • testOnReturn: 归还连接时执行validationQuery检测连接是否有效。
🍁 4.3 使用示例

以下是一个简单的 Druid 配置和使用示例:

import com.alibaba.druid.pool.DruidDataSource;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;
public class DruidExample {private static DataSource dataSource;static {DruidDataSource dds = new DruidDataSource();dds.setUrl("jdbc:mysql://localhost:3306/mydb");dds.setUsername("username");dds.setPassword("password");dds.setInitialSize(5);dds.setMinIdle(5);dds.setMaxActive(20);// 其他配置...dataSource = dds;}public static Connection getConnection() throws SQLException {return dataSource.getConnection();}public static void main(String[] args) {try (Connection conn = getConnection()) {// 使用连接进行数据库操作} catch (SQLException e) {e.printStackTrace();}}
}

在使用 Druid 时,可以通过其提供的监控界面来查看数据库连接池的状态、SQL执行情况等,这对于诊断和优化数据库性能非常有帮助。Druid 的监控功能是其一大亮点,使得它在众多数据库连接池技术中脱颖而出。

🌍 二.Apache-DBUtil

Apache DBUtils 是 Apache 软件基金会下的一个开源 Java 库,它提供了一套简单的 JDBC helper 类,用于简化数据库操作。DBUtils 主要包含两个核心类:QueryRunnerResultSetHandler。这些类可以帮助开发者执行 SQL 查询和更新,并且处理查询结果,而无需编写大量的样板代码。

为什么学习这个技术:
1.关闭connection后,resultSet结果集无法使用
2.resultSet不利于数据的管理
3.示意图

在这里插入图片描述

以下是 Apache DBUtils 的一些关键特性和用法:

❄️1. 关键特性
  1. 简化 JDBC 操作: DBUtils 封装了 JDBC 的基本操作,使得数据库操作更加简洁。
  2. 结果集处理: 提供了多种 ResultSetHandler 实现来处理查询结果,例如将结果集转换为对象列表、单个对象、数组等。
  3. 批处理支持: 支持批处理操作,可以一次性执行多个 SQL 语句。
  4. 异常处理: 提供了异常转换功能,将 SQLException 转换为未经检查的异常(如 java.lang.RuntimeException 的子类),简化异常处理。
❄️2. 主要类和方法
  • QueryRunner: 用于执行 SQL 查询和更新操作。
    • query(String sql, ResultSetHandler rsh, Object... params):执行查询操作。
    • update(String sql, Object... params):执行更新操作(INSERT、UPDATE、DELETE)。
  • ResultSetHandler: 接口,用于处理 ResultSet 对象。
    • ArrayHandler:将结果集的第一行数据转换为对象数组。
    • BeanHandler:将结果集的第一行数据转换为指定的 JavaBean 对象。
    • BeanListHandler:将结果集的所有行转换为指定 JavaBean 对象的列表。
    • ScalarHandler:用于处理单个值的结果,例如 COUNT、MAX、MIN 等。
❄️3. 使用示例

以下是一个使用 Apache DBUtils 的简单示例:

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.List;
public class DBUtilsExample {public static void main(String[] args) {QueryRunner runner = new QueryRunner();Connection conn = null;try {conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "username", "password");List<User> users = runner.query(conn, "SELECT * FROM users", new BeanListHandler<>(User.class));users.forEach(user -> System.out.println(user.getUsername()));} catch (SQLException e) {e.printStackTrace();} finally {if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}}
}
class User {private int id;private String username;// getters and setters
}

在这个例子中,我们使用 QueryRunner 来执行一个查询,并将结果集转换为 User 对象的列表。我们使用了 BeanListHandler 来处理结果集。
Apache DBUtils 是一个轻量级的库,非常适合于简单的数据库操作,特别是当你不想引入更复杂的 ORM 框架时。然而,对于更复杂的数据库操作和业务逻辑,可能需要考虑使用更全面的 ORM 框架,如 Hibernate 或 MyBatis。

🌍 三.BasicDAO

❄️1. 引入

apache-dbutils+Druid简化了JDBC开发,但还有不足:
1.SQL语句是固定,不能通过参数传入,通用性不好,需要进行改进,更方便执行增删改查
2.对于select操作,如果有返回值,返回类型不能固定,需要使用泛型
3.将来的表很多,业务需求复杂,不可能只靠一个Java类完成
4.引出=》BasicDAO画出示意图,看看在实际开发中,应该如何处理
在这里插入图片描述在这里插入图片描述

BasicDAO 是一个通用的数据访问对象(DAO)抽象层的实现,它通常用于简化数据库操作。在Java中,DAO层的主要目的是将数据库操作代码与业务逻辑代码分离,使得业务逻辑更加清晰,同时也便于数据库迁移和维护。

❄️2. BasicDAO 类通常包含以下功能:

  1. 连接管理: 管理数据库连接的创建和关闭。
  2. CRUD操作: 提供创建(Create)、读取(Read)、更新(Update)和删除(Delete)操作的通用实现。
  3. 查询执行: 执行各种SQL查询,并处理结果集。
  4. 事务管理: 管理事务的开始、提交和回滚。
    以下是一个简单的 BasicDAO 类的示例实现,它使用了 Apache Commons DBUtils 来简化操作:
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.List;
public abstract class BasicDAO<T> {private QueryRunner queryRunner = new QueryRunner();private Class<T> type;public BasicDAO(Class<T> type) {this.type = type;}protected Connection getConnection() throws SQLException {// 这里应该根据实际情况来获取数据库连接// 例如,从数据源(DataSource)获取连接return DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "username", "password");}public T queryForObject(String sql, Object... params) throws SQLException {try (Connection conn = getConnection()) {return queryRunner.query(conn, sql, new BeanHandler<>(type), params);}}public List<T> queryForList(String sql, Object... params) throws SQLException {try (Connection conn = getConnection()) {return queryRunner.query(conn, sql, new BeanListHandler<>(type), params);}}public <V> V queryForScalar(String sql, Object... params) throws SQLException {try (Connection conn = getConnection()) {return queryRunner.query(conn, sql, new ScalarHandler<V>(), params);}}public int update(String sql, Object... params) throws SQLException {try (Connection conn = getConnection()) {return queryRunner.update(conn, sql, params);}}
}

在这个 BasicDAO 类中,我们定义了几个方法来执行常见的数据库操作。这个类是泛型的,可以用于任何类型的实体类。使用时,你需要为你的实体类创建一个继承自 BasicDAO 的具体实现。

❄️3. 以下是如何使用 BasicDAO 的示例:

public class UserDao extends BasicDAO<User> {public UserDao() {super(User.class);}// 这里可以添加特定于User的数据库操作方法
}
// 使用UserDao
UserDao userDao = new UserDao();
User user = userDao.queryForObject("SELECT * FROM users WHERE id = ?", 1);
List<User> users = userDao.queryForList("SELECT * FROM users");
int updatedRows = userDao.update("UPDATE users SET username = ? WHERE id = ?", "newUsername", 1);

在这个例子中,UserDao 继承自 BasicDAO 并指定了实体类 User。然后,你可以使用 UserDao 来执行针对 User 表的数据库操作。
请注意,这个 BasicDAO 示例是一个简化版本,实际应用中可能需要更多的功能和错误处理。此外,直接使用 JDBC 和 DBUtils 可能不是最佳实践,特别是在大型或复杂的项目中,通常会使用更高级的框架如 Hibernate、MyBatis 或 Spring Data JPA 来处理数据访问层。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/893272.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux Bash 中使用重定向运算符的 5 种方法

注&#xff1a;机翻&#xff0c;未校。 Five ways to use redirect operators in Bash Posted: January 22, 2021 | by Damon Garn Redirect operators are a basic but essential part of working at the Bash command line. See how to safely redirect input and output t…

C语言内存之旅:从静态到动态的跨越

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 本文目录 引言正文一 动态内存管理的必要性二 动态…

AI时代:弯道超车的新思维与实践路径

大家好&#xff0c;我是herosunly。985院校硕士毕业&#xff0c;现担任算法研究员一职&#xff0c;热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名&#xff0c;CCF比赛第二名&#xff0c;科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的…

【Spring】定义的Bean缺少隐式依赖

问题描述 初学 Spring 时&#xff0c;我们往往不能快速转化思维。例如&#xff0c;在程序开发过程中&#xff0c;有时候&#xff0c;一方面我们把一个类定义成 Bean&#xff0c;同时又觉得这个 Bean 的定义除了加了一些 Spring 注解外&#xff0c;并没有什么不同。所以在后续使…

『 实战项目 』Cloud Backup System - 云备份

文章目录 云备份项目服务端功能服务端功能模块划分客户端功能客户端模块划分 项目条件Jsoncpp第三方库Bundle第三方库httplib第三方库Request类Response类Server类Client类搭建简单服务器搭建简单客户端 服务端工具类实现 - 文件实用工具类服务器配置信息模块实现- 系统配置信息…

网络编程 | UDP组播通信

1、什么是组播 在上一篇博客中&#xff0c;对UDP的广播通信进行了由浅入深的总结梳理&#xff0c;本文继续对UDP的知识体系进行探讨&#xff0c;旨在将UDP的组播通信由浅入深的讲解清楚。 组播是介于单播与广播之间&#xff0c;在一个局域网内&#xff0c;将某些主机添加到组中…

【无标题】微调是迁移学习吗?

是的&#xff0c;微调&#xff08;Fine-Tuning&#xff09;可以被视为一种迁移学习&#xff08;Transfer Learning&#xff09;的形式。迁移学习是一种机器学习方法&#xff0c;其核心思想是利用在一个任务上学到的知识来改进另一个相关任务的性能。微调正是通过在预训练模型的…

【HarmonyOS NAPI 深度探索12】创建你的第一个 HarmonyOS NAPI 模块

【HarmonyOS NAPI 深度探索12】创建你的第一个 HarmonyOS NAPI 模块 在本篇文章中&#xff0c;我们将一步步走过如何创建一个简单的 HarmonyOS NAPI 模块。通过这个模块&#xff0c;你将能够更好地理解 NAPI 的工作原理&#xff0c;并在你的应用中开始使用 C 与 JavaScript 的…

【电视盒子】HI3798MV300刷机教程笔记/备份遥控码修复遥控器/ADB/线刷卡刷/电视盒子安装第三方应用软件

心血来潮&#xff0c;看到电视机顶盒满天飞的广告&#xff0c;想改造一下家里的电视盒子&#xff0c;学一下网上的人刷机&#xff0c;但是一切都不知道怎么开始&#xff0c;虽然折腾了一天&#xff0c;以失败告终&#xff0c;还是做点刷机笔记。 0.我的机器 年少不会甄别&…

Python基于OpenCV和PyQt5的人脸识别上课签到系统【附源码】

博主介绍&#xff1a;✌Java老徐、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&…

【FPGA】MIPS 12条整数指令【1】

目录 修改后的仿真结果 修改后的完整代码 实现bgtz、bltz、jalr 仿真结果&#xff08;有问题&#xff09; bltz------并未跳转&#xff0c;jCe&#xff1f; 原因是该条跳转语句判断的寄存器r7&#xff0c;在该时刻并未被赋值 代码&#xff08;InstMem修改前&#xff09; i…

Java面试专题——常见面试题1

引入 本文属于专题中的常见面试题模块&#xff0c;属于面试时经常遇到的&#xff0c;适合需要面试的小伙伴做面试前复习准备用&#xff0c;后续会持续补充 1.面向对象基本特征 面向对象的基本特征是什么&#xff1f;怎么理解&#xff1f; 面向对象的基本特征是封装、继承、…

VUE实现简单留言板(Timeline+infinite scroll+Springboot+Hibernate)

先贴出效果图&#xff1a; 留言按照倒序排列。在底部的文本框内输入留言后&#xff0c;点击“留言”按钮&#xff0c;留言将保存至数据库中&#xff0c;同时刷新网页&#xff0c;新留言出现在顶部。 当滚动条到底部时&#xff0c;自动调用加载函数&#xff0c;显示更多早期留…

Java基础(3)

Java 数据类型详解 九、运算符 1. 基本运算符 Java 提供了多种运算符来执行不同的操作&#xff1a; 算术运算符&#xff1a;&#xff08;加&#xff09;、-&#xff08;减&#xff09;、*&#xff08;乘&#xff09;、/&#xff08;除&#xff09;、%&#xff08;取模&…

电力场景红外测温图像绝缘套管分割数据集labelme格式2436张1类别

数据集格式&#xff1a;labelme格式(不包含mask文件&#xff0c;仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数)&#xff1a;2436 标注数量(json文件个数)&#xff1a;2436 标注类别数&#xff1a;1 标注类别名称:["arrester"] 每个类别标注的框数&am…

降维算法:主成分分析

主成分分析 一种常用的数据分析技术&#xff0c;主要用于数据降维&#xff0c;在众多领域如统计学、机器学习、信号处理等都有广泛应用。 主成分分析是一种通过正交变换将一组可能存在相关性的变量转换为一组线性不相关的变量&#xff08;即主成分&#xff09;的方法。这些主…

深入解析 C++17 中的 u8 字符字面量:提升 Unicode 处理能力

在现代软件开发中&#xff0c;处理多语言文本是一个常见需求&#xff0c;特别是在全球化的应用场景下。C17 标准引入的 u8 字符字面量为开发者提供了一个强大的工具&#xff0c;以更有效地处理和表示 UTF-8 编码的字符串。本文将详细探讨 u8 字符字面量的技术细节、实际应用&am…

ElasticSearch索引别名的应用

个人博客&#xff1a;无奈何杨&#xff08;wnhyang&#xff09; 个人语雀&#xff1a;wnhyang 共享语雀&#xff1a;在线知识共享 Github&#xff1a;wnhyang - Overview Elasticsearch 索引别名是一种极为灵活且强大的功能&#xff0c;它允许用户为一个或多个索引创建逻辑上…

Java高频面试之SE-15

hello啊&#xff0c;各位观众姥爷们&#xff01;&#xff01;&#xff01;本牛马baby今天又来了&#xff01;哈哈哈哈哈嗝&#x1f436; String 怎么转成 Integer 的&#xff1f;它的原理是&#xff1f; 在 Java 中&#xff0c;要将 String 转换为 Integer 类型&#xff0c;可…

2024又是一年的CSDN之旅-总结过去展望未来

一、前言 一年就这样在忙忙碌碌的工作和生活中一晃而过&#xff0c;总结今年在CSDN上发表的博客&#xff0c;也有上百篇之多&#xff0c;首先感谢CSDN这个平台&#xff0c;能让我有一个地方记录工作中的点点滴滴&#xff0c;也在上面学到了不少知识&#xff0c;解决了工作中遇到…