Package java.lang.ref
Class SoftReference<T>
java.lang.Object
java.lang.ref.Reference<T>
java.lang.ref.SoftReference<T>
public class SoftReference<T> extends Reference<T>
A reference that is cleared when its referent is not strongly reachable and
there is memory pressure.
Avoid Soft References for Caching
In practice, soft references are inefficient for caching. The runtime doesn't have enough information on which references to clear and which to keep. Most fatally, it doesn't know what to do when given the choice between clearing a soft reference and growing the heap.The lack of information on the value to your application of each reference limits the usefulness of soft references. References that are cleared too early cause unnecessary work; those that are cleared too late waste memory.
Most applications should use an android.util.LruCache instead of
soft references. LruCache has an effective eviction policy and lets the user
tune how much memory is allotted.
Garbage Collection of Soft References
When the garbage collector encounters an objectobj that is
softly-reachable, the following happens:
- A set
refsof references is determined.refscontains the following elements:- All soft references pointing to
obj. - All soft references pointing to objects from which
objis strongly reachable.
- All soft references pointing to
- All references in
refsare atomically cleared. - At the same time or some time in the future, all references in
refswill be enqueued with their corresponding reference queues, if any.
SoftReferences pointing to softly reachable objects will be cleared before
the runtime throws an OutOfMemoryError.
Unlike a WeakReference, a SoftReference will not be
cleared and enqueued until the runtime must reclaim memory to satisfy an
allocation.
-
Field Summary
Fields inherited from class java.lang.ref.Reference
pendingNext -
Constructor Summary
Constructors Constructor Description SoftReference(T r)Constructs a new soft reference to the given referent.SoftReference(T r, ReferenceQueue<? super T> q)Constructs a new soft reference to the given referent. -
Method Summary
Methods inherited from class java.lang.ref.Reference
clear, enqueue, enqueueInternal, get, isEnqueued
-
Constructor Details
-
SoftReference
Constructs a new soft reference to the given referent. The newly created reference is not registered with any reference queue.- Parameters:
r- the referent to track
-
SoftReference
Constructs a new soft reference to the given referent. The newly created reference is registered with the given reference queue.- Parameters:
r- the referent to trackq- the queue to register to the reference object with. A null value results in a weak reference that is not associated with any queue.
-