手写数据库连接池(简单版本)

package cn.sxt.empmgr.dao.impl;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.LinkedList;

public class MyConnectionPool {
    //准备容器,用于 存储多个连接对象
    private static LinkedList<Connection>pool;
    //初始化容器
    static{
        //加载驱动
        try {
            Class.forName("com.mysql.jdbc.Driver");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        //预先往连接池放入一些连接对象
        pool=new LinkedList<Connection>();
        for(int i=0;i<5;i++){
            Connection conn=initConnection();
            if(null!=conn){
                System.out.println("初始化一个连接池成功,并且放入了连接池");
                pool.add(conn);
            }
        }
    }

    /**
     * 用于初始化Connection对象或者Connection代理的对象
     * @return
     */
    private static Connection initConnection(){
        try {
            Connection conn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/user","root","root");
            return conn;
        } catch (SQLException e) {
            e.printStackTrace();
        }

        return null;
    }

    /**
     * 连接池获取
     * @return
     */
    public static Connection getConnection(){
        if(pool.size()>0){
            System.out.println("连接池中还有对象,从连接池获取对象");
            //如果连接池中有连接对象,那么就直接取对象
            Connection conn=pool.removeFirst();
            return conn;
        }else{
            //连接池没有对象
            System.out.println("重新初始化一个连接对象了");
            //如果连接池中没有对象,就创建一个连接对象
            Connection conn=initConnection();
            return conn;
        }
    }

    public static void returnConnection(Connection coon){
        try {
            //判断还回来的连接池不为空,并且没有关闭,才能还回来
            if(coon!=null&&!coon.isClosed()){
                //判断连接池满了没有,没有满就放进去,满了就关闭
                if(pool.size()<10){
                    System.out.println("归还连接对象,连接池未满");
                    //取第一个,放最后一个,形成一个循环
                    pool.addLast(coon);
                }else{
                    System.out.println("连接池满了,直接关闭连接对象");
                    coon.close();
                }
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }


}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值