Interface PooledObject<T>
- Type Parameters:
T- the type of object in the pool
- All Superinterfaces:
Comparable<PooledObject<T>>
- All Known Implementing Classes:
DefaultPooledObject, PooledSoftReference
Defines the wrapper that is used to track the additional information, such as
state, for the pooled objects.
Implementations of this class are required to be thread-safe.
- Since:
- 2.0
- Version:
- $Revision: $
-
Method Summary
Modifier and TypeMethodDescriptionbooleanallocate()Allocates the object.intcompareTo(PooledObject<T> other) Orders instances based on idle time - i.e.booleanbooleanendEvictionTest(Deque<PooledObject<T>> idleQueue) Called to inform the object that the eviction test has ended.booleanlongObtain the time in milliseconds that this object last spent in the the active state (it may still be active in which case subsequent calls will return an increased value).longObtain the time (using the same basis asSystem.currentTimeMillis()) that this object was created.longObtain the time in milliseconds that this object last spend in the the idle state (it may still be idle in which case subsequent calls will return an increased value).longObtain the time the wrapped object was last borrowed.longObtain the time the wrapped object was last returned.longReturn an estimate of the last time this object was used.Obtain the underlying object that is wrapped by this instance ofPooledObject.getState()Returns the state of this object.inthashCode()voidSets the state toINVALIDvoidMarks the pooled object as abandoned.voidMarks the object as returning to the pool.voidprintStackTrace(PrintWriter writer) Prints the stack trace of the code that borrowed this pooled object and the stack trace of the last code to use this object (if available) to the supplied writer.voidsetLogAbandoned(boolean logAbandoned) Is abandoned object tracking being used? If this is true the implementation will need to record the stack trace of the last caller to borrow this object.booleanAttempt to place the pooled object in thePooledObjectState.EVICTIONstate.toString()Provides a String form of the wrapper for debug purposes.voiduse()Record the current stack trace as the last time the object was used.
-
Method Details
-
getObject
T getObject()Obtain the underlying object that is wrapped by this instance ofPooledObject.- Returns:
- The wrapped object
-
getCreateTime
long getCreateTime()Obtain the time (using the same basis asSystem.currentTimeMillis()) that this object was created.- Returns:
- The creation time for the wrapped object
-
getActiveTimeMillis
long getActiveTimeMillis()Obtain the time in milliseconds that this object last spent in the the active state (it may still be active in which case subsequent calls will return an increased value).- Returns:
- The time in milliseconds last spent in the active state
-
getIdleTimeMillis
long getIdleTimeMillis()Obtain the time in milliseconds that this object last spend in the the idle state (it may still be idle in which case subsequent calls will return an increased value).- Returns:
- The time in milliseconds last spent in the idle state
-
getLastBorrowTime
long getLastBorrowTime()Obtain the time the wrapped object was last borrowed.- Returns:
- The time the object was last borrowed
-
getLastReturnTime
long getLastReturnTime()Obtain the time the wrapped object was last returned.- Returns:
- The time the object was last returned
-
getLastUsedTime
long getLastUsedTime()Return an estimate of the last time this object was used. If the class of the pooled object implementsTrackedUse, what is returned is the maximum ofTrackedUse.getLastUsed()andgetLastBorrowTime(); otherwise this method gives the same value asgetLastBorrowTime().- Returns:
- the last time this object was used
-
compareTo
Orders instances based on idle time - i.e. the length of time since the instance was returned to the pool. Used by the GKOP idle object evictor.Note: This class has a natural ordering that is inconsistent with equals if distinct objects have the same identity hash code.
- Specified by:
compareToin interfaceComparable<T>
-
equals
-
hashCode
-
toString
-
startEvictionTest
boolean startEvictionTest()Attempt to place the pooled object in thePooledObjectState.EVICTIONstate.- Returns:
trueif the object was placed in thePooledObjectState.EVICTIONstate otherwisefalse
-
endEvictionTest
Called to inform the object that the eviction test has ended.- Parameters:
idleQueue- The queue of idle objects to which the object should be returned- Returns:
- Currently not used
-
allocate
-
deallocate
-
invalidate
void invalidate()Sets the state toINVALID -
setLogAbandoned
void setLogAbandoned(boolean logAbandoned) Is abandoned object tracking being used? If this is true the implementation will need to record the stack trace of the last caller to borrow this object.- Parameters:
logAbandoned- The new configuration setting for abandoned object tracking
-
use
void use()Record the current stack trace as the last time the object was used. -
printStackTrace
Prints the stack trace of the code that borrowed this pooled object and the stack trace of the last code to use this object (if available) to the supplied writer.- Parameters:
writer- The destination for the debug output
-
getState
-
markAbandoned
void markAbandoned()Marks the pooled object as abandoned. -
markReturning
void markReturning()Marks the object as returning to the pool.
-