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