Package org.geotools.util
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>
public class WeakValueHashMap<K,V> extends AbstractMap<K,V>
A hashtable-basedMap
implementation with weak values. An entry in aWeakValueHashMap
will automatically be removed when its value is no longer in ordinary use. This class is similar to the standardWeakHashMap
class provided in J2SE, except that weak references are hold on values instead of keys.The
WeakValueHashMap
class is thread-safe.- Since:
- 2.0
- Author:
- Martin Desruisseaux (IRD)
- See Also:
WeakHashMap
,WeakHashSet
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class AbstractMap
AbstractMap.SimpleEntry<K extends Object,V extends Object>, AbstractMap.SimpleImmutableEntry<K extends Object,V extends Object>
-
-
Constructor Summary
Constructors Constructor Description WeakValueHashMap()
Creates aWeakValueHashMap
.WeakValueHashMap(int initialSize)
Creates aWeakValueHashMap
of the requested size and default load factor.WeakValueHashMap(Map<K,V> map)
Creates a newWeakValueHashMap
populated with the contents of the provied map.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
clear()
Removes all of the elements from this map.boolean
containsKey(Object key)
Returnstrue
if this map contains a mapping for the specified key.boolean
containsValue(Object value)
Returnstrue
if this map maps one or more keys to this value.Set<Map.Entry<K,V>>
entrySet()
Returns a set view of the mappings contained in this map.V
get(Object key)
Returns the value to which this map maps the specified key.V
put(K key, V value)
Associates the specified value with the specified key in this map.V
remove(Object key)
Removes the mapping for this key from this map if present.int
size()
Returns the number of key-value mappings in this map.-
Methods inherited from class AbstractMap
clone, equals, hashCode, isEmpty, keySet, putAll, toString, values
-
Methods inherited from interface Map
compute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll
-
-
-
-
Method Detail
-
size
public int size()
Returns the number of key-value mappings in this map.
-
containsValue
public boolean containsValue(Object value)
Returnstrue
if this map maps one or more keys to this value.- Specified by:
containsValue
in interfaceMap<K,V>
- Overrides:
containsValue
in classAbstractMap<K,V>
- Parameters:
value
- value whose presence in this map is to be tested.- Returns:
true
if this map maps one or more keys to this value.
-
containsKey
public boolean containsKey(Object key)
Returnstrue
if this map contains a mapping for the specified key.- Specified by:
containsKey
in interfaceMap<K,V>
- Overrides:
containsKey
in classAbstractMap<K,V>
- Parameters:
key
- key whose presence in this map is to be tested.- Returns:
true
if this map contains a mapping for the specified key.- Throws:
NullPointerException
- If key isnull
.
-
get
public V get(Object key)
Returns the value to which this map maps the specified key. Returnsnull
if the map contains no mapping for this key.- Specified by:
get
in interfaceMap<K,V>
- Overrides:
get
in classAbstractMap<K,V>
- Parameters:
key
- Key whose associated value is to be returned.- Returns:
- The value to which this map maps the specified key.
- Throws:
NullPointerException
- if the key isnull
.
-
put
public V put(K key, V value)
Associates the specified value with the specified key in this map. The value is associated using aWeakReference
.- Specified by:
put
in interfaceMap<K,V>
- Overrides:
put
in classAbstractMap<K,V>
- Parameters:
key
- key with which the specified value is to be associated.value
- value to be associated with the specified key.- Returns:
- previous value associated with specified key, or
null
if there was no mapping for key. - Throws:
NullPointerException
- if the key or the value isnull
.
-
clear
public void clear()
Removes all of the elements from this map.
-
-