Apache Common-pool2对象池浅析

人走茶凉 提交于 2019-12-17 19:48:16

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

        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.

 

 

引用:

apache commons pool2的整体结构分析

Apache Common-pool2对象池分析和应用

Apache common-pool,common-dbcp源码解读与对象池原理剖析

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!