Package org.apache.sis.util.collection
Class WeakValueHashMap<K,V> 
Object
AbstractMap<K,V>
 
WeakValueHashMap<K,V> 
- Type Parameters:
- K- the class of key elements.
- V- the class of value elements.
- All Implemented Interfaces:
- Map<K,- V> 
A hashtable-based map implementation that uses weak references,
 leaving memory when an entry is not used anymore. An entry in a 
WeakValueHashMap
 will automatically be removed when its value is no longer in ordinary use. This class is
 similar to the standard WeakHashMap class, except that weak references
 apply to values rather than keys.
 Note that this class is not a cache, because the entries are discarded
 as soon as the garbage collector determines that they are no longer in use. If caching
 service are wanted, or if concurrency are wanted, consider using Cache instead.
This class is convenient for avoiding the creation of duplicated elements, as in the example below:
K key = ...
V value;
synchronized (map) {
    value = map.get(key);
    if (value == null) {
        value = ...; // Create the value here.
        map.put(key, value);
    }
}WeakValueHashMap instance
 is not expected to be used in a highly concurrent environment.
 WeakValueHashMap works with array keys as one would expect. For example, arrays of int[] are
 compared using the Arrays.equals(int[], int[]) method.
Thread safety
The sameWeakValueHashMap instance can be safely used by many threads without synchronization on the part
 of the caller. But if a sequence of two or more method calls need to appear atomic from other threads perspective,
 then the caller can synchronize on this.- Since:
- 0.3
- See Also:
Defined in the sis-utility module
- 
Nested Class SummaryNested classes/interfaces inherited from class AbstractMapAbstractMap.SimpleEntry<K,V>, AbstractMap.SimpleImmutableEntry<K, V> 
- 
Constructor SummaryConstructorsConstructorDescriptionWeakValueHashMap(Class<K> keyType) Creates a newWeakValueHashMap.WeakValueHashMap(Class<K> keyType, boolean identity) Creates a newWeakValueHashMap, optionally using reference-equality in place of object-equality.
- 
Method SummaryModifier and TypeMethodDescriptionvoidclear()Removes all of the elements from this map.booleancontainsKey(Object key) Returnstrueif this map contains a mapping for the specified key.booleancontainsValue(Object value) Returnstrueif this map maps one or more keys to this value.Set<Map.Entry<K,V>> Returns a set view of the mappings contained in this map.Returns the value to which this map maps the specified key.Associates the specified value with the specified key in this map.putIfAbsent(K key, V value) Associates the specified value with the specified key in this map if no value were previously associated.Removes the mapping for this key from this map if present.booleanRemoves the entry for the specified key only if it is currently mapped to the specified value.Replaces the entry for the specified key only if it is currently mapped to some value.booleanReplaces the entry for the specified key only if currently mapped to the specified value.intsize()Returns the number of key-value mappings in this map.Methods inherited from class AbstractMapclone, equals, hashCode, isEmpty, keySet, putAll, toString, valuesMethods inherited from interface Mapcompute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, replaceAll
- 
Constructor Details- 
WeakValueHashMapCreates a newWeakValueHashMap.- Parameters:
- keyType- the type of keys in the map.
 
- 
WeakValueHashMapCreates a newWeakValueHashMap, optionally using reference-equality in place of object-equality. Ifidentityistrue, then two keysk1andk2are considered equal if and only if(k1 == k2)instead of ifk1.equals(k2).Reference-equality semantic is rarely used. See the IdentityHashMapclass javadoc for a discussion about drawbacks and use cases when reference-equality semantic is useful.- Parameters:
- keyType- the type of keys in the map.
- identity-- trueif the map shall use reference-equality in place of object-equality when comparing keys, or- falsefor the standard behavior.
- Since:
- 0.4
 
 
- 
- 
Method Details- 
sizepublic int size()Returns the number of key-value mappings in this map.
- 
containsKeyReturnstrueif this map contains a mapping for the specified key. Null keys are considered never present.- Specified by:
- containsKeyin interface- Map<K,- V> 
- Overrides:
- containsKeyin class- AbstractMap<K,- V> 
- Parameters:
- key- key whose presence in this map is to be tested.
- Returns:
- trueif this map contains a mapping for the specified key.
 
- 
containsValueReturnstrueif this map maps one or more keys to this value. Null values are considered never present.- Specified by:
- containsValuein interface- Map<K,- V> 
- Overrides:
- containsValuein class- AbstractMap<K,- V> 
- Parameters:
- value- value whose presence in this map is to be tested.
- Returns:
- trueif this map maps one or more keys to this value.
 
- 
getReturns the value to which this map maps the specified key. Returnsnullif the map contains no mapping for this key. Null keys are considered never present.
- 
putAssociates the specified value with the specified key in this map. The value is associated using aWeakReference.- Specified by:
- putin interface- Map<K,- V> 
- Overrides:
- putin class- AbstractMap<K,- V> 
- Parameters:
- key- key with which the specified value is to be associated.
- value- value to be associated with the specified key.
- Returns:
- the previous value associated with specified key, or nullif there was no mapping for the key.
- Throws:
- NullArgumentException- if the key or the value is- null.
 
- 
putIfAbsentAssociates the specified value with the specified key in this map if no value were previously associated. If another value is already associated to the given key, then the map is left unchanged and the current value is returned. Otherwise the specified value is associated to the key using aWeakReferenceandnullis returned.- Parameters:
- key- key with which the specified value is to be associated.
- value- value to be associated with the specified key.
- Returns:
- the current value associated with specified key, or nullif there was no mapping for the key.
- Throws:
- NullArgumentException- if the key or the value is- null.
- Since:
- 0.7
 
- 
replaceReplaces the entry for the specified key only if it is currently mapped to some value.- Parameters:
- key- key with which the specified value is to be associated.
- value- value to be associated with the specified key.
- Returns:
- the previous value associated with specified key, or nullif there was no mapping for the key.
- Throws:
- NullArgumentException- if the value is- null.
- Since:
- 1.2
 
- 
replaceReplaces the entry for the specified key only if currently mapped to the specified value.- Parameters:
- key- key with which the specified value is to be associated.
- oldValue- value expected to be associated with the specified key.
- newValue- value to be associated with the specified key.
- Returns:
- trueif the value was replaced.
- Throws:
- NullArgumentException- if the new value is- null.
- Since:
- 1.2
 
- 
removeRemoves the mapping for this key from this map if present.
- 
removeRemoves the entry for the specified key only if it is currently mapped to the specified value.- Parameters:
- key- key whose mapping is to be removed from the map.
- value- value expected to be associated with the specified key.
- Returns:
- trueif the value was removed.
- Since:
- 1.2
 
- 
clearpublic void clear()Removes all of the elements from this map.
- 
entrySetReturns a set view of the mappings contained in this map. Each element in this set is aMap.Entry.
 
-