項目介紹:
Apache的Commons Pool庫提供了一個對象池化API和大量的對象池實現。 與1.x系列相比common pool 2 完全重寫的池化實現。 除了性能和可擴展性改進之外,common pool 2還包括強大的實例跟蹤和池監視。 common pool 2需要JDK1.6或更高版本。
源碼分析
-
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方法如下:

方法說明:
- `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。如果不是所有資源都可以釋放,實現應該默認失敗。