一、 XXXObjectPoolFactory
这些类用来生成相应的XXXObjectPool,比如GenericKeyedObjectPoolFactory:这个类用来生成一个新的GenericKeyedObjectPool对象。它实际的作用只是保存创建一个GenericKeyedObjectPool对象所需要的配置参数。如果使用默认的配置参数生成一个GenericKeyedObjectPool对象,那么可以调用GenericKeyedObjectPoolFactory(KeyedPoolableObjectFactory factory, GenericKeyedObjectPool.Config config),其中Config类里保存所有的缺省配置参数。
二、GenericKeyedObjectPool
通过_poolMap来管理相应的对象链,key作为寻找不同对象链的线索。也就是说,一个GenericKeyedObjectPool中可以管理多个不同key的对象集合,每个集合通过_activeMap用来保存各个不同的Key当前的活动对象的数量(闲置对象的数量可以直接通过相应的CursorableLinkedList的size来获取),可以通过getNumActive(Object key)和getNumIdle(Object key)方法获取这
两个值。这个对象集合通过CursorableLinkedList来管理。
这个类里的_maxIdle和_maxActive属性是针对单个key对应的CursorableLinkedList而言的最大值,而_maxTotal属性则是对所有的key表示的对象集合的总和的最大值。_totalActive+_totalIdle用来和_maxTotal的值进行对比,它们可以通过getNumActive()和getNumIdle()获取。_poolList存放的值与 _poolMap 中的key值一样,注意这个对象不是没有用处的,因为CursorableLinkedList是一个允许多个线程同步迭代的类。
1、几个内置的static类型的变量:
WHEN_EXHAUSTED_FAIL 这个属性表明当对象池已经用尽时(比如说池中的对象数目已经达到了最大值),borrowObject方法应该立刻抛出NoSuchElementException异常。
WHEN_EXHAUSTED_BLOCK 这个属性表明当对象池已经用尽时(比如说池中的对象数目已经达到了最大值),borrowObject方法应该等待,直到对象池中有一个对象可以让它返回,或者达到了最大等待时间(DEFAULT_MAX_WAIT)。
WHEN_EXHAUSTED_GROW 这个属性表明即使在对象池已经用尽时(比如说池中的对象数目已经达到了最大值),borrowObject方法应该仍旧返回一个对象。
DEFAULT_WHEN_EXHAUSTED_ACTION 这个属性表明当对象池用尽的时候(比如说池中的对象数目已经达到了最大值)应该采取上面的那种策略。
DEFAULT_MAX_IDLE 和 DEFAULT_MAX_ACTIVE分别指定了在池中对大的空闲和活动对象的数目。DEFAULT_MAX_TOTAL表明对象池允许存在的最大对象数量。
2、CursorableLinkedList
它实际是一个双向列表,与LinkedList的区别是:它允许多个线程执行迭代。它的实现思路是:在每次生成一个Cursor时:CursorableLinkedList.Cursor cursor(int i),都会吧这个新生成的Cursor对象包装到一个 WeakReference 中:_cursors.add( new WeakReference(cur) );在不需要的的时候需要调用Cursor. close()方法取消注册。而Cursor实际是一个以内嵌类的方式的实现了ListIterator接口的类。WeakReference 不会增加被其包装的类的引用次数,换句话说,它不会影响JVM的垃圾收集。
3、borrowObject(Object key)
这个方法用来从相应的key表示的对象集合中取出一个对象。如果对应的对象集合不存在,会创建一个这样的集合。如果集合当前没有闲置的对象可以返回,并且当前的active < _maxActive && totalActive + _totalIdle < _maxTotal,那么通过KeyedPoolableObjectFactory创建一个新的对象;否则就根据_whenExhaustedAction的设定执行相应的操作。要注意每次都会执行_factory.activateObject(key,pair.value)方法初始化这个对象。在返回这个对象之前,如果设定了_testOnBorrow标志则调用_factory.validateObject(Object key, Object obj)方法,如果不符合要求会抛出NoSuchElementException异常,否则返回这个对象。
4、returnObject(Object key, Object obj)
这个方法用来把一个对象返回给key表示的对象集合,这个方法的执行过程与borrowObject(Object key)方法相似。它会根据_testOnReturn标志执行_factory.validateObject(Object key, Object obj)方法检查返回的对象是否合格。要注意每次都会执行 _factory.passivateObject(key, obj)方法“消除”这个对象。
5、过期类的回收:
Evictor 为一个内嵌类,实现自Runnable接口。它每过_timeBetweenEvictionRunsMillis毫秒会调用一次evict()方法,在后台收集垃圾寿命超过_minEvictableIdleTimeMillis毫秒的对象。每当我们创建一个GenericKeyedObjectPool对象的时候,这个类会被自动创建,并且被启动。evict() 方法很简单,它首先创建一个_evictionKeyCursor = _poolList.cursor()对象,然后根据key遍历每一个对象集合。
查找到过期的就会删除。
三、[url=http://www.bt285.cn]SoftReferenceObjectPool
[/url] 通过SoftReference进行对象的保存,这个SoftReference的好处是你不需要自己进行收集,它会在JVM的内存用尽时被自动回收。这种对象池的特色是:
a、可以保存任意多个对象,不会有容量已满的情况发生。
b、在对象池已空的时候,调用它的borrowObject方法,会自动返回新创建的实例。
c、可以在初始化同时,在池内预先创建一定量的对象。
d、当内存不足的时候,池中的对象可以被Java虚拟机回收。
四、StackObjectPool 和 StackKeyedObjectPool
通过一个Stack对对象进行管理,要注意这个Stack是继承自Vector对象的。因此虽然线程安全,但是效率较低。这种对象池的特色是:
a、可以为对象池指定一个初始的参考大小(当空间不够时会自动增长)。
b、在对象池已空的时候,调用它的borrowObject方法,会自动返回新创建的实例。
c、可以为对象池指定一个可保存的对象数目的上限。达到这个上限之后,再向池里送回的对象会被自动送去回收。
五、PoolableObjectFactory
Pool组件利用PoolableObjectFactory来照看被池化的对象。ObjectPool的实例在需要处理被池化的对象的产生、激活、挂起、校验和销毁工作时,就会调用跟它关联在一起的PoolableObjectFactory实例的相应方法来操作。 用户需要自己实现这个接口。
呵呵.N年前的东西,从MSN space 转过来了.
分享到:
相关推荐
标题中的"commons-dbcp-1.2.2-src.zip"表示的是Apache Commons DBCP 1.2.2版本的源代码压缩包。源代码对于开发者来说是宝贵的资源,因为它允许深入理解组件的工作原理,进行定制化修改,以及排查可能出现的问题。 ...
含源代码,由于文件大小限制,lib目录下的jar文件已经被删除,需要自己上网下载,列表如下: antlr-2.7.5H3.jar asm.jar aspectjweaver-1.5.2a.jar cglib-nodep-2.1_3.jar commons-beanutils-1.7.1-20061106.jar ...
教学-传智播客-项目视频经典之作巴巴运动网106集-27实现Web层的分页功能源代码 所需要的jar文件: (一)、Hibernate: 位于 "\hibernate-distribution-3.3.2.GA" 目录下的jar文件: hibernate3.jar 位于 "\...
教学-传智播客-项目视频经典之作巴巴运动网106集-27实现Web层的分页功能源代码 所需要的jar文件: (一)、Hibernate: 位于 "\hibernate-distribution-3.3.2.GA" 目录下的jar文件: hibernate3.jar 位于 "\...
教学-传智播客-项目视频经典之作巴巴运动网106集-28将Web层分页封装成通用模块源代码 所需要的jar文件: (一)、Hibernate: 位于 "\hibernate-distribution-3.3.2.GA" 目录下的jar文件: hibernate3.jar 位于 "\...
3. **commons-pool-1.3.jar**:Apache Commons Pool是对象池设计模式的实现,它是DBCP的基础。对象池技术允许程序预先创建一定数量的对象,供多个线程共享,减少对象的创建和销毁带来的开销。在Struts数据源配置中,...
在给定的压缩包中,包含了三个重要的Apache Commons库,它们分别是`commons-collections3.1.jar`, `commons-dbcp.jar`和`commons-pool-1.4.jar`,这些库有助于实现高效的数据源管理。 1. **Apache Commons ...
教学-传智播客-项目视频经典之作巴巴运动网106集-28将Web层分页封装成通用模块源代码 所需要的jar文件: (一)、Hibernate: 位于 "\hibernate-distribution-3.3.2.GA" 目录下的jar文件: hibernate3.jar 位于 "\...
在给定的压缩包文件中,我们关注的是"commons_pool"、"commons_dbcp"以及"struts_legacy",这些都是Java开发中的重要组件,特别是对于构建Web应用程序时。 首先,`commons_pool`是Apache Commons的一个项目,它提供...
在这个场景中,提到的"struts连接数据要用到的jar文件"主要包括了三个关键组件,它们是`commons-dbcp-1.2.1.zip`、`commons-pool-current.zip`和`struts-legacy.jar`。这些文件在Java应用中起着不同的作用: 1. **...
这些库主要来自于Apache Commons项目,包括`commons-collections.jar`,`commons-dbcp-1.2.1.jar`以及`commons-pool-1.2.jar`。现在我们将详细讲解这三个jar包及其在Struts框架中配置数据源时的作用。 1. **commons...
- **jakarta-struts-1.1-b1-src.zip**:包含 Struts 的源代码。 - **jakarta-struts-1.1-b1-lib.zip**:包含 Struts 运行所需的库文件。 ##### 2.2 软件需求 为了能够顺利地使用 Struts 构建 Web 应用程序,还需要...
3. **commons-pool-1.1.jar**:Apache Commons Pool是对象池设计模式的一个实现,主要用于数据库连接池。在DBCP中,它被用来管理数据库连接的生命周期,包括创建、分配、回收和销毁连接。这个库提供了对象池服务,...
1. Activation-1.1.jar:该jar包与JavaMail相关,是JavaMail规范的一部分,用于处理邮件的数据源和类型。当使用JavaMail发送邮件时,需要将其与mail.jar一起添加到项目的类路径中。 2. Antlr-2.7.6.jar:ANTLR是一...
- 其他依赖的 Jakarta Commons 包,包括 BeanUtils、Collections、DBCP、Logging、Pool、Services 和 Validator,以及 Digester 和 Xalan XSLT 处理器。 3. **从源代码构建 Struts** - 在 Windows 2000 操作系统...
Struts DataSource Lib是一个关于Apache Struts框架与数据源库的集成。这个压缩包包含了两个重要的Java库文件:`commons-dbcp.jar`和`commons-pool.jar`,它们是Apache Commons项目的一部分,主要用于数据库连接池的...
3. **commons-dbcp.jar** 和 **commons-pool.jar**:这些包分别用于数据库连接池管理和通用对象池管理。`commons-dbcp`是基于`commons-pool`实现的数据库连接池组件,可以有效提高数据库访问效率并减少资源消耗。 ...
- **Apache Commons POOL**:[commons-pool-1.6-bin.zip](http://commons.apache.org/proper/commons-pool/download_pool.cgi) - **MySQL JDBC驱动**:自行下载。 #### 二、搭建步骤 **3.1 新建WEB工程** - **...
* commons-pool.jar * dom4j-1.6.1.jar * hibernate-jpa-2.0-api-1.0.1.Final.jar * hibernate3.jar * jta-1.1.jar * mysql-connector-java-5.1.18-bin.jar * org.springframework.jdbc-3.1.1.RELEASE.jar 配置文件...
需要的jar文件有数据库连接相关jar文件如下:commons- dbcp.jarcommons-logging.jarcommons-pool.jarmysql-connector-java-3.1.11- bin.jaribaits框架jar文件如下:ibatis-2.3.4.726.jar配置数据库连接。ibaits配置...