分享

commons

 360lec 2017-05-02

一、背景介绍

    创建新的对象并初始化的操作,可能会消耗很多的时间。在需要频繁创建并使用这些对象的场景中,为了提供系统性能,通常的做法是,创建一个对象池,将一定数量的对象缓存到这个对象池中。需要使用时直接从对象池中取出对象,使用完后将对象扔回到对象池中即可。Apachecommons pool组件是我们实现对象池化技术的良好助手。

二、组件基本介绍 

该项目是一个基本的对象池组件;Pool提供三个主要方面对象池的API:

a)  一个提供客户方和实现方用来实现简单、可变的对象池的基本接口。

b)  一个用来创建模块化对象池的工具。

c)  几个通用的对象池的实现。

 

三、组件特点

    org.apache.commons.pool包定义了一部分在创建一个新的对象池实现时十分有用的接口和基本类。

四、对象池

    (1)ObjectPool    

    ObjectPool定义了一个简单小巧的池化接口,主要有GenericObjectPool、StackObjectPool、SoftReferenceObjectPool三个实现类;

    a)GenericObjectPool:可配置LIFO/FIFO行为的ObjectPool的实现。默认采用LIFO队列方式。这意味着当有闲置的可用对象在对象池中时,borrowObject方法会返回最近的实例。如果配置文件中的lifo配置项的值为false,则将返回相反排序的实例,也就是会返回最先进入对象池的对象的实例。

    b)StackObjectPool:使用LIFO行为实现的ObjectPool

    c)SoftReferenceObjectPool:使用LIFO行为实现的ObjectPool。此外,在这个对象池实现中,每个对象都会被包装到一个SoftReference中。SoftReference允许垃圾回收机制在需要释放内存时回收对象池中的对象。

    (2)KeyedObjectPool

    KeyedObjectPool对象池有多种类型情况的对象池的实现,每种类型对应一个任意的键值,组件给出了GenericKeyedObjectPool、StackKeyedObjectPool两个基本的实现类;

    a)GenericKeyedObjectPool:通过FIFO行为实现的对象池。

    b)StackKeyedObjectPool:通过LIFO行为实现的对象池。

五、PoolableObjectFactory、ObjectPool及ObjectPoolFactory

 commons pool组件中,对象池化的工作被划分给了三类对象: PoolableObjectFactoryExample.java

(1)       PoolableObjectFactory用于管理池化对象的产生、激活、挂起、校验和销毁;

 

(2)       ObjectPool用于管理要被池化的对象的借出和归还,同时通知PoolableObjectFactory完成相应的工作;

(3)       ObjectPoolFactory则用于大量生成相同类型和设置的ObjectPool;

     相应的,使用Pool组件的过程,也可大体划分成“实现自己的PoolableObjectFactory”、“使用

  ObjectPool”和可选的“利用ObjectPoolFactory”三个步骤。

(1) 实现自己的PoolableObjectFactory

     ObjectPool的实例在需要处理池化的对象的产生、激活、挂起、校验和销毁工作时,就会调用跟它

 关联在一起的PoolableObjectFactory实例的相应方法来操作。PoolableObjectFactory是commons-pool

 中定义个一个接口,Pool组件中没有包含任何一种PoolableObjectFactory实现,需要根据情况自行创立。

 

Java代码 复制代码 收藏代码
  1. // 该方法用于产生你要放入到对象池中的新对象   
  2. Object makeObject() throws Exception;   
  3.   
  4. // 该方法用于销毁对象   
  5. void destroyObject(Object obj) throws Exception;   
  6.   
  7.   
  8. boolean validateObject(Object obj);   
  9.   
  10.   
  11. void activateObject(Object obj) throws Exception;   
  12.   
  13. // 该方法用于将对象“挂起”,将对象设置为休眠状态即不可用   
  14. void passivateObject(Object obj) throws Exception;  

 

 

 

ObjectPool是Pool组件中定义的一个接口,实际使用的时候同样需要利用这个接口的具

体实现。Pool组件本身提供了几种实现,可以直接使用。当然也可以自行创建。

ObjectPool的使用方法:

(a)、  生成一个要用的PoolableObjectFactory类的实例

PoolableObjectPoolFactory factory = new PoolableObjectPoolFactoryExample();

(b)、  利用PoolableObjectPoolFactory实例为参数,生成一个实现了ObjectPool接口的类的实

例,作为对象池ObjectPool pool = new StackObjectPool(factory);

(c)、  需要从对象池中获取对象时,调用对应的borrowObject()方法Object obj = pool.borrowObject();

(d)、  将对象放回对象池中,调用returnObject(Object obj)方法pool.returnObject(obj);

(e)、  当不再需要对象池时,直接调用对象池上的close()方法,释放资源。pool.close();

另外,ObjectPool接口还定义了几个可以由具体的实现决定要不要支持的操作,包括:

void clear()

清除所有当前在此对象池中休眠的对象。

int getNumActive()

返回已经从此对象池中借出的对象的总数。

int getNumIdle()

返回当前在此对象池中休眠的对象的数目。

void setFactory(PoolableObjectFactory factory)

将当前对象池与参数中给定的PoolableObjectFactory相关联。如果在当前状态下,无法

完成这一操作,会有一个IllegalStateException异常抛出。

(3)使用ObjectPoolFactory

ObjectPoolFactory是Pool组件中定义的一个接口,它定义了一个createPool()方法,可以

用于大量产生类型和设置都相同的ObjectPool的对象。

Pool组件中,对每一个ObjectPool的实现,都有一个对应的ObjectPoolFactory实现。

最后给出一个较为完整的例子:

 

Java代码 复制代码 收藏代码
  1. package org.apache.commons.pool;   
  2.   
  3. public class PoolableObjectFactoryExample implements PoolableObjectFactory   
  4. {   
  5.       
  6.     private static int count 0;   
  7.   
  8.       
  9.     @Override  
  10.     public void activateObject(Object obj) throws Exception   
  11.     {   
  12.         System.out.println("destroyObject run obj);   
  13.     }   
  14.   
  15.       
  16.     @Override  
  17.     public void destroyObject(Object obj) throws Exception   
  18.     {   
  19.         System.out.println("destroyObject run obj);   
  20.     }   
  21.   
  22.       
  23.     @Override  
  24.     public Object makeObject() throws Exception   
  25.     {   
  26.         String obj String.valueOf(count);   
  27.         System.out.println("makeObject run obj);   
  28.         return obj;   
  29.     }   
  30.   
  31.       
  32.     @Override  
  33.     public void passivateObject(Object obj) throws Exception   
  34.     {   
  35.         System.out.println("passivateObject run obj);   
  36.     }   
  37.   
  38.       
  39.     @Override  
  40.     public boolean validateObject(Object obj)   
  41.     {   
  42.         boolean flag false;   
  43.         if(obj.equals(obj))   
  44.         {   
  45.             flag true;   
  46.         }   
  47.         return flag;   
  48.     }   
  49.   
  50.  

 

ObjectPoolExample.java
Java代码 复制代码 收藏代码
  1. package org.apache.commons.pool;   
  2.   
  3. import org.apache.commons.pool.impl.StackObjectPoolFactory;   
  4.   
  5. public class ObjectPoolExample   
  6. {   
  7.     public static void main(String[] args)   
  8.     {   
  9.         // 生成PoolableObjectFactory实例   
  10.         PoolableObjectFactory _factory new PoolableObjectFactoryExample();   
  11.         // 生成一个ObjectPoolFactory实例   
  12.         ObjectPoolFactory objFactory new StackObjectPoolFactory(_factory);   
  13.         // 生成一个ObjectPool实例   
  14.         ObjectPool pool objFactory.createPool();   
  15.         // 获取对象池中的一个可用对象   
  16.         try  
  17.         {   
  18.             Object obj pool.borrowObject();   
  19.             // 使用对象   
  20.             pool.returnObject(obj);   
  21.             obj null;   
  22.         }   
  23.         catch(Exception ex)   
  24.         {   
  25.             ex.printStackTrace();   
  26.         }   
  27.         finally  
  28.         {   
  29.             try  
  30.             {   
  31.                 // 关闭对象池   
  32.                 pool.close();   
  33.                 pool null;   
  34.             }   
  35.             catch(Exception ex)   
  36.             {   
  37.                 ex.printStackTrace();   
  38.             }   
  39.         }   
  40.     }   
  41.  

 

 

来自http://blog.sina.com.cn/s/blog_9076f9ba01016fap.html

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多