Cleaners are a lightweight and more robust alternative to finalization. They are lightweight because they are not created by the VM and thus do not require a JNI upcall to be created, and because their cleanup code is invoked directly by the reference-handler thread rather than by the finalizer thread. They are more robust because they use phantom references, the weakest type of reference object, thereby avoiding the nasty ordering problems inherent to finalization.
A cleaner tracks a referent object and encapsulates a thunk of arbitrary cleanup code. Some time after the GC detects that a cleaner's referent has become phantom-reachable, the reference-handler thread will run the cleaner. Cleaners may also be invoked directly; they are thread safe and ensure that they run their thunks at most once.
Cleaners are not a replacement for finalization. They should be used only when the cleanup code is extremely simple and straightforward. Nontrivial cleaners are inadvisable since they risk blocking the reference-handler thread and delaying further cleanup and finalization.
Modifier and Type | Field and Description |
---|---|
private static final ReferenceQueue | |
private static Cleaner | |
private Cleaner | |
private Cleaner | |
private final Runnable |
Access | Constructor and Description |
---|---|
private |
Modifier and Type | Method and Description |
---|---|
private static synchronized Cleaner | |
public void | |
public static Cleaner | |
private static synchronized boolean |
dummyQueue | back to summary |
---|---|
private static final ReferenceQueue<Object> dummyQueue |
first | back to summary |
---|---|
private static Cleaner first |
next | back to summary |
---|---|
private Cleaner next Hides java. |
prev | back to summary |
---|---|
private Cleaner prev |
thunk | back to summary |
---|---|
private final Runnable thunk |
Cleaner | back to summary |
---|---|
private Cleaner(Object referent, Runnable thunk) |
add | back to summary |
---|---|
private static synchronized Cleaner add(Cleaner cl) |
clean | back to summary |
---|---|
public void clean() Runs this cleaner, if it has not been run before.
|
create | back to summary |
---|---|
public static Cleaner create(Object ob, Runnable thunk) Creates a new cleaner. |
remove | back to summary |
---|---|
private static synchronized boolean remove(Cleaner cl) |