Modifier and Type | Class and Description |
---|---|
private static class |
Modifier and Type | Field and Description |
---|---|
private transient Reference | |
pack-priv volatile Reference | |
private static boolean | |
private static final Object | |
pack-priv volatile ReferenceQueue | |
private T |
Access | Constructor and Description |
---|---|
pack-priv | |
pack-priv |
Modifier and Type | Method and Description |
---|---|
public void | |
private native void | |
pack-priv void | |
protected Object | Returns: never returns normallyOverrides java. Throws |
public boolean | Returns: true if this reference object was successfully
enqueued; false if it was already enqueued or if
it was not registered with a queue when it was createdClears this reference object, then attempts to add it to the queue with which it is registered, if any. |
private void | |
public T | Returns: The object to which this reference refers, ornull if this reference object has been clearedReturns this reference object's referent. |
private static native Reference | |
pack-priv T | |
private static native boolean | |
public boolean | Returns: true if and only if this reference object is
in its associated queue (if any).
Deprecated
since 16. This method was originally specified to test if a reference object has
been cleared and enqueued but was never implemented to do this test.
Tests if this reference object is in its associated queue, if any. |
private static void | |
public static void | reachabilityFence(Object
the reference to the object to keep strongly reachable. If
ref)null , this method has no effect.Ensures that the given object remains strongly reachable. |
public final boolean | Returns: true if obj is the referent of this reference objectthe object to compare with this reference object's referent obj)Tests if the referent of this reference object is |
private native boolean | |
pack-priv boolean | |
pack-priv static void | |
private static native void | |
private static boolean |
discovered | back to summary |
---|---|
private transient Reference<?> discovered |
next | back to summary |
---|---|
pack-priv volatile Reference<T> next
|
processPendingActive | back to summary |
---|---|
private static boolean processPendingActive |
processPendingLock | back to summary |
---|---|
private static final Object processPendingLock |
queue | back to summary |
---|---|
pack-priv volatile ReferenceQueue<? super T> queue |
referent | back to summary |
---|---|
private T referent |
Reference | back to summary |
---|---|
pack-priv Reference(T referent) |
Reference | back to summary |
---|---|
pack-priv Reference(T referent, ReferenceQueue<? super T> queue) |
clear | back to summary |
---|---|
public void clear() Clears this reference object. Invoking this method does not enqueue this object, and the garbage collector will not clear or enqueue this object. When the garbage collector or the API Note There is a potential race condition with the garbage collector. When this
method is called, the garbage collector may already be in the process of
(or already completed) clearing and/or enqueueing this reference.
Avoid this race by ensuring the referent remains strongly reachable until
after the call to clear(), using |
clear0 | back to summary |
---|---|
private native void clear0() |
clearInactiveFinalReference | back to summary |
---|---|
pack-priv void clearInactiveFinalReference() Clear referent with strong semantics. |
clone | back to summary |
---|---|
protected Object clone() throws CloneNotSupportedException Overrides java. Throws
|
enqueue | back to summary |
---|---|
public boolean enqueue() Clears this reference object, then attempts to add it to the queue with which it is registered, if any. If this reference is registered with a queue but not yet enqueued,
the reference is added to the queue; this method is
successful and returns true.
If this reference is not registered with a queue, or was already enqueued
(by the garbage collector, or a previous call to Memory consistency effects:
Actions in a thread prior to a successful call to When this method clears references it does so directly, without
invoking the API Note Use of this method allows the registered queue's
|
enqueueFromPending | back to summary |
---|---|
private void enqueueFromPending() |
get | back to summary |
---|---|
public T get() Returns this reference object's referent. If this reference object has
been cleared, either by the program or by the garbage collector, then
this method returns API Note This method returns a strong reference to the referent. This may cause
the garbage collector to treat it as strongly reachable until some later
collection cycle. The
|
getAndClearReferencePendingList | back to summary |
---|---|
private static native Reference |
getFromInactiveFinalReference | back to summary |
---|---|
pack-priv T getFromInactiveFinalReference() Load referent with strong semantics. |
hasReferencePendingList | back to summary |
---|---|
private static native boolean hasReferencePendingList() |
isEnqueued | back to summary |
---|---|
public boolean isEnqueued()
Deprecated since 16. This method was originally specified to test if a reference object has
been cleared and enqueued but was never implemented to do this test.
This method could be misused due to the inherent race condition
or without an associated Tests if this reference object is in its associated queue, if any.
This method returns
false .
This method may return false if this reference object has been cleared
but not enqueued due to the race condition.
|
processPendingReferences | back to summary |
---|---|
private static void processPendingReferences() |
reachabilityFence | back to summary |
---|---|
public static void reachabilityFence(Object ref) Ensures that the given object remains strongly reachable. This reachability is assured regardless of any optimizing transformations the virtual machine may perform that might otherwise allow the object to become unreachable (see JLS 12.6.1). Thus, the given object is not reclaimable by garbage collection at least until after the invocation of this method. References to the given object will not be cleared (or enqueued, if applicable) by the garbage collector until after invocation of this method. Invocation of this method does not itself initiate reference processing, garbage collection, or finalization. This method establishes an ordering for strong reachability
with respect to garbage collection. It controls relations that are
otherwise only implicit in a program -- the reachability conditions
triggering garbage collection. This method is applicable only
when reclamation may have visible effects,
such as for objects that use finalizers or Memory consistency effects:
Actions in a thread prior to calling API Note Reference processing or finalization can occur after an object becomes
unreachable. An object can become unreachable when the virtual machine
detects that there is no further need for the object (other than for
running a finalizer). In the course of optimization, the virtual machine
can reorder operations of an object's methods such that the object
becomes unneeded earlier than might naively be expected —
including while a method of the object is still running. For instance,
the VM can move the loading of values from the object's fields
to occur earlier. The object itself is then no longer needed and becomes
unreachable, and the method can continue running using the obtained values.
This may have surprising and undesirable effects when using a Cleaner or
finalizer for cleanup: there is a race between the
program thread running the method, and the cleanup thread running the
Cleaner or finalizer. The cleanup thread could free a
resource, followed by the program thread (still running the method)
attempting to access the now-already-freed resource.
Use of
The following is an example in which the bookkeeping associated with a class is
managed through array indices. Here, method class Resource {
private static ExternalResource[] externalResourceArray = ...
int myIndex;
Resource(...) {
this.myIndex = ...
externalResourceArray[myIndex] = ...;
...
}
protected void finalize() {
externalResourceArray[this.myIndex] = null;
...
}
public void action() {
try {
// ...
int i = this.myIndex; // last use of 'this' Resource in action()
Resource.update(externalResourceArray[i]);
} finally {
Reference.reachabilityFence(this);
}
}
private static void update(ExternalResource ext) {
ext.status = ...;
}
}
reachabilityFence is
placed after the call to update , to ensure that the
array slot is not nulled out by Object#finalize before the
update, even if the call to action was the last use of this
object. This might be the case if, for example, a usage in a user program
had the form new Resource().action(); which retains no other
reference to this Resource .
The reachabilityFence call is placed in a finally block to
ensure that it is invoked across all paths in the method. A more complex
method might need further precautions to ensure that
reachabilityFence is encountered along all code paths.
Method
|
refersTo | back to summary |
---|---|
public final boolean refersTo(T obj) Tests if the referent of this reference object is
|
refersTo0 | back to summary |
---|---|
private native boolean refersTo0(Object o)
|
refersToImpl | back to summary |
---|---|
pack-priv boolean refersToImpl(T obj) |
startReferenceHandlerThread | back to summary |
---|---|
pack-priv static void startReferenceHandlerThread(ThreadGroup tg) Start the Reference Handler thread as a daemon thread. |
waitForReferencePendingList | back to summary |
---|---|
private static native void waitForReferencePendingList() |
waitForReferenceProcessing | back to summary |
---|---|
private static boolean waitForReferenceProcessing() throws InterruptedException |
Access | Constructor and Description |
---|---|
pack-priv |
Modifier and Type | Method and Description |
---|---|
public void | run()
Overrides java. Implements java. This method is run by the thread when it executes. |
ReferenceHandler | back to summary |
---|---|
pack-priv ReferenceHandler(ThreadGroup g, String name) |
run | back to summary |
---|---|
public void run() Overrides java. Implements java. Doc from java. This method is run by the thread when it executes. Subclasses of This method is not intended to be invoked directly. If this thread is a
platform thread created with a |