Java自定义连接池

本文介绍了如何在Java中自定义数据库连接池,通过LinkedList存储连接,并在静态代码块中初始化。文章详细讲解了创建获取和归还连接的方法,并讨论了如何实现DataSource接口以集成更多功能。最后,为了解决connection对象的close方法导致的连接销毁问题,文章引入了动态代理来增强close方法,确保其执行归还连接操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先我们要定义一个连接池,就需要存储一些连接在里面,我们就需要集合来存储。当然这个连接池需要定义在静态代码块里面,集合定义在静态代码块里面,我们就需要在静态代码块外面定义一个集合成员变量。那我们定义连接池的集合就需要使用LinkedList集合啦。

​
    //1.定义一个集合成员变量
    private static LinkedList<Connection> pools=new LinkedList<>();
    //2.在静态代码块中初始化一些连接
    static {
        for (int i = 0; i < 5; i++) {
        // 有异常我们try,catch
            try {
                //注册驱动
                Class.forName("com.mysql.jdbc.Driver");

                //创建连接,这个连接是连接我自己的数据库
                String url="jdbc:mysql://localhost:3306/day16_1?useSSL=false";
                Connection connection= DriverManager.getConnection(url,"root","root");

                //把连接添加到连接池的容器当中
                pools.add(connection);
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
    }

​

现在我们有了5个连接对象,接下来我们需要提供2个非静态的方法,一个用来获取连接,一个用来归还连接,我们还可以定义一个方法来获取连接池中的连接数量

    //3.提供非静态的方法,用来获取一个连接
    public Connection getCon(){
        //从连接池中获得一个连接
        Connection connection=pools.removeFirst();
        //返回连接
        return  connection;
    }
    //4.提供非静态方法,用来归还连接
    public void addBack
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值