Apache Common-pool2包提供了一个通用的对象池技术的实现。能够很方便的基于它来实现本身的对象池,好比DBCP和Jedis他们的内部对象池的实现就是依赖于Common-pool2。
对象的建立和销毁在必定程度上会消耗系统的资源,虽然jvm的性能在近几年已经获得了很大的提升,对于多数对象来讲,没有必要利用对象池技术来进行对象的建立和管理。可是对于有些对象来讲,其建立的代价仍是比较昂贵的,好比线程、tcp链接、数据库链接等对象,所以对象池技术仍是有其存在的意义。数据库
1.Apache Common-pool2的实现apache
common-pool2包括三个包:swift
org.apache.commons.pool2:包含了对象池的接口。框架
org.apache.commons.pool2.impl:包含了对象池的具体实现。jvm
org.apache.commons.pool2.proxy:包含了对象池的代理。tcp
commons-pool2主要有三大部分构成:ObjectPool,PooledObjectFactory,PooledObject。性能
ObjectPool:咱们直接操做的对象池,主要包括对象的存取和状态的管理,具体对象的建立由PooledObjectFactory来实现。.net
PooledObjectFactory:管理具体对象的状态,好比建立,初始化,验证对象状态和销毁对象。线程
PooledObject:是对须要放入池中的对象的一个包装类,给对象添加了一些额外的信息,如状态信息,建立时间,激活时间,关闭时间等。这些添加的信息方便pool来管理和实现一些特定的操做。代理
他们这三者就构成了一个object pool的基本框架。他们的关系能够用以下的一个图来描述:
简单来讲,就是由PooledObjectFactory建立对象,而后由PooledObject包装一下,放入ObjectPool.
引用: