连接池的使用

手动实现连接池

 

package com.offcn.Mypool01;

 

import java.sql.Connection;

import java.util.ArrayList;

import java.util.List;

 

import com.offcn.utils.JdbcUtils;

 

/*

*作者: 中公-qf_meng

*时间:202076 上午10:33:55

*描述: 手动实现连接池

*/

public class MyDBConnectionPool {

       //clist是一个连接池

       private static List<Connection> clist=new ArrayList<Connection>();

       private static int num=5;

       //1.java应用程序初始的时候,默认存放一些连接到连接池

       static {

              for(int i=1;i<=num;i++) {

                     clist.add(JdbcUtils.getConnetion());

              }

              System.out.println("连接池初始化的连接数量为:"+clist.size());

       }

       //2.获取连接

       public static Connection getConnection() {

              System.out.println("======获取连接=======");

              Connection connection=null;

              //判断连接池中是否还有连接

              if(clist.size()>0) {

                     //获取连接

                     connection=clist.get(0);

                     //把获取到的在集合中删除

                     clist.remove(0);

              }else {

                     System.out.println("等待连接2s.....");

                     //等待连接2s

                     try {

                            Thread.sleep(2000);

                     } catch (InterruptedException e) {

                            e.printStackTrace();

                     }

                     //再次获取连接

                     connection=getConnection();

              }

              System.out.println("获取连接后===连接池的连接数量为-----"+clist.size());

              return connection;

       }

       //3.关闭连接

       public static void closeConnection(Connection connection) {

              System.out.println("=====归还连接=======");

              if(connection!=null) {

                     //把连接还给连接池

                     clist.add(connection);

              }

              System.out.println("归还连后==连接池的连接数量为-----"+clist.size());

       }

}

 

  1. 测试类:

 

package com.offcn.test;

 

import java.sql.Connection;

 

import com.offcn.Mypool01.MyDBConnectionPool;

 

/*

*作者: 中公-qf_meng

*时间:202076 上午10:46:49

*描述:

*/

public class MyDBConnectionPoolTest {

       public static void main(String[] args) {

              //获取连接

              //Connection connection = MyDBConnectionPool.getConnection();

              //System.out.println(connection);

              //关闭连接

              //MyDBConnectionPool.closeConnection(connection);

             

              for (int i = 1; i <=8; i++) {

                     Connection connection = MyDBConnectionPool.getConnection();

              }

       }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值