怎么利用等待wait,唤醒notifyall超时模式,手写一个简单数据库连接池

本文通过一个简单的数据库连接池实现,详细解释了如何运用wait和notifyAll方法,旨在教授这两种多线程通信机制的使用。通过阅读,读者将了解如何在实际场景中创建并管理数据库连接池。
摘要由CSDN通过智能技术生成

背景

今天主要讲解一下如何利用wait, notifyall 手写一个数据库连接池,闲话不多说,下面上代码

连接池类

package cn.enjoyedu.ch1.pool;

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

/**
 *类说明:连接池的实现
 */
public class DBPool {
   

    /*容器,存放连接*/
    private static LinkedList<Connection> pool = new LinkedList<Connection>();

    /*限制了池的大小=20*/
    public DBPool(int initialSize) {
   
        if (initialSize > 0) {
   
            for (int i = 0; i < initialSize; i++) {
   
                pool.addLast(SqlConnectImpl.fetchConnection());
            }
        }
    }

    /*释放连接,通知其他的等待连接的线程*/
    public void releaseConnection(Connection connection) {
   
        if (connection != null) {
   
            synchronized (pool){
   
                pool.addLast(connection);
                //通知其他等待连接的线程
                pool.notifyAll();
            }
        }
    }

    /*获取*/
    // 在mills内无法获取到
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值