java并发实战:连接池实现
池化技术简介 在我们使用数据库的过程中,我们往往使用数据库连接池而不是直接使用数据库连接进行操作,这是因为每一个数据库连接的创建和销毁的代价是昂贵的,而池化技术则预先创建了资源,这些资源是可复用的,这样就保证了在多用户情况下只能使用指定数目的资源,避免了一个用户创建一个连接资源,造成程序运行开销过大。 关于Java并发编程的总结和思考 连接池实现原理 这里只实现一个简易的连接池,更多复杂的需求可根据该连接池进行改进,该连接池主要参数如下: 一个繁忙队列busy 一个空闲队列idle 连接池最大活动连接数maxActive 连接池最大等待时间maxWait 连接池的活动连接数activeSize 程序流程图如下: 代码实现 泛型接口ConnectionPool.java public interface ConnectionPool<T> { /** * 初始化池资源 * @param maxActive 池中最大活动连接数 * @param maxWait 最大等待时间 */ void init(Integer maxActive, Long maxWait); /** * 从池中获取资源 * @return 连接资源 */ T getResource() throws Exception; /** * 释放连接 * @param connection 正在使用的连接 */