Class Reference<T>
- Direct Known Subclasses:
FinalizerReference,PhantomReference,SoftReference,WeakReference
public abstract class Reference<T> extends Object
Reference in addition to the ones provided by this package. It is
also not desirable to do so, since references require very close cooperation
with the system's garbage collector. The existing, specialized reference
classes should be used instead.
Three different type of references exist, each being weaker than the preceding one:
SoftReference, WeakReference, and
PhantomReference. "Weakness" here means that less restrictions are
being imposed on the garbage collector as to when it is allowed to
actually garbage-collect the referenced object.
In order to use reference objects properly it is important to understand the different types of reachability that trigger their clearing and enqueueing. The following table lists these, from strongest to weakest. For each row, an object is said to have the reachability on the left side if (and only if) it fulfills all of the requirements on the right side. In all rows, consider the root set to be a set of references that are "resistant" to garbage collection (that is, running threads, method parameters, local variables, static fields and the like).
| Strongly reachable |
|
| Softly reachable |
|
| Weakly reachable |
|
| Phantom-reachable |
|
-
Field Summary
Fields Modifier and Type Field Description Reference<?>pendingNextUsed internally by the VM. -
Method Summary
Modifier and Type Method Description voidclear()Makes the referentnull.booleanenqueue()Forces the reference object to be enqueued if it has been associated with a queue.booleanenqueueInternal()Adds an object to its reference queue.Tget()Returns the referent of the reference object.booleanisEnqueued()Checks whether the reference object has been enqueued.
-
Field Details
-
pendingNext
Used internally by the VM. This field forms a circular and singly linked list of reference objects discovered by the garbage collector and awaiting processing by the reference queue thread.
-
-
Method Details
-
clear
public void clear()Makes the referentnull. This does not force the reference object to be enqueued. -
enqueueInternal
public final boolean enqueueInternal()Adds an object to its reference queue.- Returns:
trueif this call has caused theReferenceto become enqueued, orfalseotherwise
-
enqueue
public boolean enqueue()Forces the reference object to be enqueued if it has been associated with a queue.- Returns:
trueif this call has caused theReferenceto become enqueued, orfalseotherwise
-
get
Returns the referent of the reference object.- Returns:
- the referent to which reference refers, or
nullif the object has been cleared.
-
isEnqueued
public boolean isEnqueued()Checks whether the reference object has been enqueued.- Returns:
trueif theReferencehas been enqueued,falseotherwise
-