Package org.apache.hadoop.hbase.util
Class ObjectPool<K,V> 
java.lang.Object
org.apache.hadoop.hbase.util.ObjectPool<K,V> 
- Direct Known Subclasses:
- SoftObjectPool,- WeakObjectPool
A thread-safe shared object pool in which object creation is expected to be lightweight, and the
 objects may be excessively created and discarded.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic interfaceAnObjectFactoryobject is used to create new shared objects on demand.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intThe default concurrency level, used when not otherwise specified in a constructor.static final intThe default initial capacity, used when not otherwise specified in a constructor.private final ObjectPool.ObjectFactory<K,V> private final LockFor preventing parallel purgeprotected final ConcurrentMap<K,Reference<V>> Does not permit null keys.protected final ReferenceQueue<V>
- 
Constructor SummaryConstructorsConstructorDescriptionObjectPool(ObjectPool.ObjectFactory<K, V> objectFactory) Creates a new pool with the default initial capacity (16) and the default concurrency level (16).ObjectPool(ObjectPool.ObjectFactory<K, V> objectFactory, int initialCapacity) Creates a new pool with the given initial capacity and the default concurrency level (16).ObjectPool(ObjectPool.ObjectFactory<K, V> objectFactory, int initialCapacity, int concurrencyLevel) Creates a new pool with the given initial capacity and the given concurrency level.
- 
Method SummaryModifier and TypeMethodDescriptioncreateReference(K key, V obj) Create a reference associated with the given objectReturns a shared object associated with the givenkey, which is identified by theequalsmethod.abstract KgetReferenceKey(Reference<V> ref) Get key of the given referencevoidpurge()Removes stale references of shared objects from the pool.intsize()Returns an estimated count of objects kept in the pool.
- 
Field Details- 
staleRefQueue
- 
objectFactory
- 
referenceCacheDoes not permit null keys.
- 
purgeLockFor preventing parallel purge
- 
DEFAULT_INITIAL_CAPACITYThe default initial capacity, used when not otherwise specified in a constructor.- See Also:
 
- 
DEFAULT_CONCURRENCY_LEVELThe default concurrency level, used when not otherwise specified in a constructor.- See Also:
 
 
- 
- 
Constructor Details- 
ObjectPoolCreates a new pool with the default initial capacity (16) and the default concurrency level (16).- Parameters:
- objectFactory- the factory to supply new objects on demand
- Throws:
- NullPointerException- if- objectFactoryis null
 
- 
ObjectPoolCreates a new pool with the given initial capacity and the default concurrency level (16).- Parameters:
- objectFactory- the factory to supply new objects on demand
- initialCapacity- the initial capacity to keep objects in the pool
- Throws:
- NullPointerException- if- objectFactoryis null
- IllegalArgumentException- if- initialCapacityis negative
 
- 
ObjectPoolpublic ObjectPool(ObjectPool.ObjectFactory<K, V> objectFactory, int initialCapacity, int concurrencyLevel) Creates a new pool with the given initial capacity and the given concurrency level.- Parameters:
- objectFactory- the factory to supply new objects on demand
- initialCapacity- the initial capacity to keep objects in the pool
- concurrencyLevel- the estimated count of concurrently accessing threads
- Throws:
- NullPointerException- if- objectFactoryis null
- IllegalArgumentException- if- initialCapacityis negative or- concurrencyLevelis non-positive
 
 
- 
- 
Method Details- 
purgeRemoves stale references of shared objects from the pool. References newly becoming stale may still remain. The implementation of this method is expected to be lightweight when there is no stale reference with the Oracle (Sun) implementation ofReferenceQueue, becauseReferenceQueue.polljust checks a volatile instance variable inReferenceQueue.
- 
createReferenceCreate a reference associated with the given object- Parameters:
- key- the key to store in the reference
- obj- the object to associate with
- Returns:
- the reference instance
 
- 
getReferenceKeyGet key of the given reference- Parameters:
- ref- The reference
- Returns:
- key of the reference
 
- 
getReturns a shared object associated with the givenkey, which is identified by theequalsmethod.- Throws:
- NullPointerException- if- keyis null
 
- 
sizeReturns an estimated count of objects kept in the pool. This also counts stale references, and you might want to callpurge()beforehand.
 
-