Jakarta Commons项目研究 --pool
一.pool项目到底什么是 pool, 简单来说, 就是先建立一些存在的 object, 放在 pool 之中,当你有需要的时候,可以从 pool 中直接获取,不需要重新建立. . 最常听到的就是 database connection pooling, 因为建立数据库连结是一件耗时的工作, 如果我们先把连结建立好, 就 可以节省这一些时间。database connection pooling 即DBCP。
1.基础类结构 pool的基础类:
public interface ObjectPool {
Object borrowObject();
void returnObject(Object borrowed);
}
主要扩展类 :
public interface KeyedObjectPool
{
Object borrowObject(Object key);
void returnObject(Object key, Object borrowed);
}
按照key来索引pool的对象 基础类仅提供了最基本的两个函数,用来创建和返回pool对象。
2.实现的基本类 BaseObjectPool--PoolableObjectFactory--BasePoolableObjectFactory KeyedObjectPool--KeyedPoolableObjectFactory--BaseKeyedPoolableObjectFactory StackObjectPool--StackKeyedObjectPool--可以在初始化创建实例,提供有限的 idle 数量GenericObjectPool--GenericKeyedObjectPool--包含了设定 idle, active 的数量以及回收到pool中的设置SoftReferenceObjectPool--可以随需要进行增加,他的回收是由垃圾回收站进行的总的来说,它提供了 Pool 的 API 主要有三个方面: 提供一般性的对象 pool 接口, 可以简单地去使用和实现. 比如BaseObjectPool和KeyedObjectPool. 提供小工具可以建立模块化的 pool. 比如StackObjectPool. 实现出一些通用性的 pool. 比如GenericObjectPool.
3.实现
ObjectPool
Object obj = null;
try
{
//创建对象
obj = pool.borrowObject();
//捕获异常
}
catch (Exception e) { }
finally
{
//确认对象是否已经返回
if(null != obj) {
pool.returnObject(obj);
}
}
KeyedObjectPool Object obj = null;
Object key = "Key";
try
{
//创建对象
obj = pool.borrowObject(key);
//捕获异常
}
catch (Exception e) { }
finally
{
//确认返回
if(null != obj) {
pool.returnObject(key, obj);
}
}
其它的类型继承开发就可以了
4.范例(取自apache的commons组) ReaderUtil.java
import java.io.Reader;
import java.io.IOException;
public class ReaderUtil {
public ReaderUtil() { }
/** * Dumps the contents of the {@link Reader} to a *
String, closing the {@link Reader} when done.
*/
public String readToString(Reader in) throws IOException
{
StringBuffer buf = new StringBuffer();
try {
for( int c = in.read(); c != -1; c = in.read())
{
buf.append((char) c);
}
return buf.toString();
} catch (IOException e) {
throw e;
} finally {
try {
in.close();
} catch (Exception e)
{
// ignored } } }
}
改换一下顺序, 先取得pool, 再由pool取值( 推荐使用)
import org.apache.commons.pool.ObjectPool;
import java.io.Reader;
import java.io.IOException;
public class ReaderUtil {
private ObjectPool pool;
public ReaderUtil(ObjectPool pool) {
this.pool = pool;
}
/** * Dumps the contents of the {@link Reader} to a * String,
closing the {@linkReader} when done.
*/
public String readToString(Reader in) throws IOException {
StringBuffer buf = null;
try {
buf = (StringBuffer) (pool.borrowObject());
for (int c = in.read(); c != -1; c = in.read()) {
buf.append((char) c);
}
return buf.toString();
} catch (IOException e) {
throw e;
} catch (Exception e) {
throw new RuntimeException("Unable to borrow buffer from pool" + e.toString());
} finally {
try {
in.close();
} catch (Exception e) {
// ignored } try { if(null != buf) { pool.returnObject(buf);
}
} catch(Exception
e) { // ignored } } } }
用StringBuffer做pool的例子(不推荐使用,仅供熟悉知识)
StringBufferFactory.java
import org.apache.commons.pool.BasePoolableObjectFactory;
public class StringBufferFactory extends BasePoolableObjectFactory {
// for makeObject we'll simply return a new buffer
public Object makeObject() {
return new StringBuffer();
}
// when an object is returned to the pool,
// we'll clear it out
public void passivateObject(Object obj) {
StringBuffer buf = (StringBuffer) obj;
buf.setLength(0);
}
// for all other methods, the no-op
// implementation in BasePoolableObjectFactory
// will suffice }
修改 ReaderUtil 由 StringBufferFactory Pool 得到 StringBuffer.
new ReaderUtil(
new StackObjectPool( new StringBufferFactory() ) )
5.总结我们通常会在 io 的部分采用 pool 机制, 减少一些建立存取的时间, 对于最耗时的数据
库存取, 更是相对的重要,我将会在commons-DBCP专题进行介绍,本篇是本系列的第二篇
分享到:
相关推荐
DBCP(DataBase Connection Pool)是 apache common上的一个 java 连接池项目,也是 tomcat 使用的连接池组件,依赖 于Jakarta commons-pool 对象池机制,DBCP可以直接的在应用程序中使用。 使用DBCP会用到commons-...
DBCP(Database Connection Pool)是Apache Jakarta项目中的一个子项目,它利用了commons-pool对象池机制来实现数据库连接的复用,从而减少创建和释放数据库连接时的开销。Tomcat,一个广泛使用的Java应用服务器,...
3. `commons-pool-1.6.jar`:Apache Commons Pool是通用的对象池服务,它是DBCP连接池依赖的基础。DBCP利用了Pool库来实现对象(这里是数据库连接)的池化管理,包括创建、分配、回收和销毁连接等操作。 使用DBCP...
DBCP(DataBase Connection Pool)是 apache common上的一个 java 连接池项目,也是 tomcat 使用的连接池组件,依赖 于Jakarta commons-pool 对象池机制,DBCP可以直接的在应用程序中使用。 使用DBCP会用到commons-...
jakarta-commons 相关依赖包,文件列表: commons-attributes-api.jar commons-attributes-compiler.jar commons-beanutils.jar commons-codec.jar commons-collections.jar commons-dbcp.jar commons-digester.jar ...
在描述中提到了两个具体的版本号:“commons-dbcp-1.2.2.jar”和“commons-pool-1.3.jar”。这两个版本是较旧的,可能不包含最新的性能优化和安全修复。通常建议使用较新的稳定版本以获得更好的兼容性和安全性。不过...
Apache Commons DBCP是Apache软件基金会的Jakarta项目下的一个子项目,主要功能是提供数据库连接池服务。数据库连接池是一种在应用服务器启动时预创建一定数量的数据库连接,并将这些连接存储在一个池中,当多个用户...
Jakarta Commons Pool是一个用于在Java程序中实现对象池化的组件。它的基本情况是: 主要作者:Morgan Delagrange、Geir Magnusson、Craig McClanahan、Rodney Waldhoff、David Weinrich和Dirk Verbeeck 最新版本:...
4. `jakarta-pool-1.5.2.jar`: 这是Apache Commons Pool的核心库文件,包含了所有必需的类和接口,用于实现对象池。 5. `jakarta-pool-1.5.2-sources.jar`: 源代码jar文件,可以用于查看和理解Pool库的内部工作原理...
1. **添加依赖:** 首先需要将`commons-dbcp-1.2.1.jar`和`commons-pool-current.jar`(这里可能是`commons-pool-x.x.x.jar`,具体版本取决于描述中的`current`所指)添加到项目的类路径中。如果是Maven项目,可以在...
Commons-Pool 提供了通用对象池接口,一个用于创建模块化对象池的工具包,以及通常的对象池实现. Primitives Commons-Primitives提供了一个更小,更快和更易使用的对Java基本类型的支持。当前主要是针对基本类型的 ...
commons-pool 提供了通用对象池接口,一个用于创建模块化对象池的工具包,以及通常的对象池实 commons-primitives java 简单类型使用的扩展 commons-proxy 创建动态代理的库 commons-scxml commons-transaction ...
commons-pool 提供了通用对象池接口,一个用于创建模块化对象池的工具包,以及通常的对象池实 commons-primitives java 简单类型使用的扩展 commons-proxy 创建动态代理的库 commons-scxml commons-transaction ...
Apache Commons DBCP 是基于Jakarta POI和Jakarta Pool项目开发的,旨在解决Java应用程序在处理大量并发数据库操作时的性能问题。 1. **数据库连接池原理**: 数据库连接池在初始化时会创建一定数量的数据库连接,...
《Jakarta Commons Cookbook》是Java开发领域中一本非常实用的指南,主要涵盖了Apache Jakarta Commons组件的使用技巧和最佳实践。这本书旨在帮助开发者更好地理解和利用Jakarta Commons库中的各种工具类和模块,...
9. **DBCP和POOL**:数据库连接池组件,如Commons-DBCP和Commons-POOL,它们提高了数据库连接的管理和性能,降低了资源消耗。 10. **Email组件**:发送电子邮件的工具,支持多种邮件协议,如SMTP、SMTPS等,可以...
DBCP是基于Jakarta-pool对象池实现的数据库连接池组件,它在JDBC API之上提供了一层封装,使得开发者能够更方便地管理和复用数据库连接。DBCP 1.4是该组件的一个稳定版本,它包含了对多种数据库的兼容性支持,如...
### Apache Jakarta Commons 使用手册知识点详解 #### 一、概述 《Apache Jakarta Commons 使用手册》是一部详细介绍Apache Jakarta Commons项目下的各种Java组件的专业书籍。该书由Will Iverson编写,旨在为...
commons-pool dom4j-1.6.1 dwr ehcache-1.1 hibernate3 itext-1.3 jaas jakarta-oro-2.0.8 jaxen-1.1-beta-7 jdbc2_0-stdext jotm json-lib-2.3-jdk15-javadoc jta jxl log4j-1.2.11 log4j-1.2.14 portlet-api ...
5. **pool-1.5.6.jar**: 这可能是Apache Commons Pool的1.5.6版本,这是一个通用的对象池服务。虽然描述中没有明确指出,但考虑到DBCP,这可能是一个错误,因为DBCP已经内置了自己的连接池实现。如果存在独立的...