common pool分析

項目地址

項目介紹:

Apache的Commons Pool庫提供了一個對象池化API和大量的對象池實現。 與1.x系列相比common pool 2 完全重寫的池化實現。 除了性能和可擴展性改進之外,common pool 2還包括強大的實例跟蹤和池監視。 common pool 2需要JDK1.6或更高版本。

源碼分析

  1. ObjectPool接口:

    • 使用Demo:
    try {
       obj = pool.borrowObject();
       try {
           //...使用對象...
       } catch(Exception e) {
           // 使用對象過程中出現異常時,失效緩存池中的對象
           pool.invalidateObject(obj);
           // 將池化對象設置為null,防止將池化的對象返回給對象池兩次
           obj = null;
       } finally {
           // 在finally中確保池化對象返還給對象池
           if(null != obj) {
               pool.returnObject(obj);
          }
       }
    } catch(Exception e) {
         // failed to borrow an object
    }
    

- ObjectPool方法如下:

![](http://upload-images.jianshu.io/upload_images/1370674-e487d0d26eec58e3.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

方法說明:
- `borrowObject`:
    - 從對象池中獲取一個實例,這個實例是通過PooledObjectFactory.makeObject新創建的,或者是以前空閑的對象,但是已經使用PooledObjectFactory.activateObject激活,然后使用PooledObjectFactory.validateObject驗證的。按照約定,客戶端必須使用returnObject,invalidateObject或者在子類\子接口中定義的相關方法返回借用的實例。
- `returnObject`:
    - 將實例返回到池。按照約定,obj必須是使用borrowObject()或者子類中實現的相關方法獲得的。
- `invalidateObject`:
    - 使池中的對象無效。按照約定,obj必須使用borrowObject()或子類中中實現的相關方法獲得。當已借用的對象(由于異常或其他問題)被確定為無效時,應使用此方法。
- `addObject`:
    - 使用工廠或其他相關機制創建對象,將其鈍化,然后將其放置在空閑對象池中。 addObject對于用空閑對象“預加載”池是十分有用(可選操作)。
- `getNumIdle`:
    - 返回此池中當前空閑的實例數,可以近似認為是不用創建任何新實例的對象就可以借用的數量。 如果此信息不可用,則返回負值。
- `getNumActive`:
    - 返回當前從此池中借用的實例數。 如果此信息不可用,則返回負值。
- `clear`:
    - 清除池中處于空閑狀態的任何對象,釋放所有相關資源。被清空的空閑對象必須是PooledObjectFactory.destroyObject()。
- `close`:
    - 關閉此池,并釋放與其關聯的任何資源。在池上調用此方法后調用addObject或borrowObject將導致它們拋出IllegalStateException。如果不是所有資源都可以釋放,實現應該默認失敗。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容