1f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes/*
2adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Licensed to the Apache Software Foundation (ASF) under one or more
3adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * contributor license agreements.  See the NOTICE file distributed with
4adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * this work for additional information regarding copyright ownership.
5adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * The ASF licenses this file to You under the Apache License, Version 2.0
6adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * (the "License"); you may not use this file except in compliance with
7adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * the License.  You may obtain a copy of the License at
8f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *
9adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     http://www.apache.org/licenses/LICENSE-2.0
10f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *
11adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Unless required by applicable law or agreed to in writing, software
12adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
13adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * See the License for the specific language governing permissions and
15adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * limitations under the License.
16adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */
17adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/*
18adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Copyright (C) 2008 The Android Open Source Project
19adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *
20adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
21adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * you may not use this file except in compliance with the License.
22adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * You may obtain a copy of the License at
23adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *
24adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
25adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *
26adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Unless required by applicable law or agreed to in writing, software
27adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
28adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
29adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * See the License for the specific language governing permissions and
30adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * limitations under the License.
31adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */
32adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
33adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpackage java.lang.ref;
34adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
35adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/**
36adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements a soft reference, which is the least-weak of the three types of
37adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * references. Once the garbage collector has decided that an object {@code obj}
38016a87c7952b25eededfc222615e25a5a72bcddaScott Main * is softly-reachable, the following
39adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * may happen, either immediately or at a later point:
40f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *
41adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * <ul>
42adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   <li>
43adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     A set {@code ref} of references is determined. {@code ref} contains the
44adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     following elements:
45adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     <ul>
46adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *       <li>
47adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *         All soft references pointing to {@code obj}.
48adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *       </li>
49adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *       <li>
50adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *         All soft references pointing to objects from which {@code obj} is
51adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *         strongly reachable.
52adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *       </li>
53adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     </ul>
54adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   </li>
55adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   <li>
56adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     All references in {@code ref} are atomically cleared.
57adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   </li>
58adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   <li>
59adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     At the same time or some time in the future, all references in {@code
60adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     ref} will be enqueued with their corresponding reference queues, if any.
61f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *   </li>
62adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * </ul>
63f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *
64adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * The system may decide not to clear and enqueue soft references until a later
65adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * time, yet all {@code SoftReference}s pointing to softly reachable objects are
66adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * guaranteed to be cleared before the VM will throw an {@link
67adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * java.lang.OutOfMemoryError}.
68f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *
69adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Soft references are useful for caches that should automatically have
70adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * their entries removed once they are not referenced any more (from outside),
71adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * and there is a need for memory. The difference between a {@code
72adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * SoftReference} and a {@code WeakReference} is the point of time at which the
73adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * decision is made to clear and enqueue the reference:
74f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *
75adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * <ul>
76adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   <li>
77adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     A {@code SoftReference} should be cleared and enqueued <em>as late as
78adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     possible</em>, that is, in case the VM is in danger of running out of
79adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     memory.
80adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   </li>
81adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   <li>
82adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     A {@code WeakReference} may be cleared and enqueued as soon as is
83f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes *     known to be weakly-referenced.
84adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *   </li>
85adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * </ul>
86adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */
87adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpublic class SoftReference<T> extends Reference<T> {
88adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
89adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
90adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new soft reference to the given referent. The newly created
91adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * reference is not registered with any reference queue.
92f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
93adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param r the referent to track
94adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
95adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public SoftReference(T r) {
96adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        super();
97adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        referent = r;
98adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
99f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes
100adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
101adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new soft reference to the given referent. The newly created
102adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * reference is registered with the given reference queue.
103f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
104adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param r the referent to track
105adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param q the queue to register to the reference object with. A null value
106adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *          results in a weak reference that is not associated with any
107adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *          queue.
108adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
109adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public SoftReference(T r, ReferenceQueue<? super T> q) {
110adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        super();
111adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        referent = r;
112adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        queue = q;
113adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
114adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project}
115