Package java.util.concurrent
Interface ConcurrentMap<K,V>
-
- Type Parameters:
K- the type of keys maintained by this mapV- the type of mapped values
- All Superinterfaces:
Map<K,V>
- All Known Subinterfaces:
ConcurrentNavigableMap<K,V>
- All Known Implementing Classes:
ConcurrentHashMap,ConcurrentSkipListMap
public interface ConcurrentMap<K,V> extends Map<K,V>
AMapproviding additional atomicputIfAbsent,remove, andreplacemethods.Memory consistency effects: As with other concurrent collections, actions in a thread prior to placing an object into a
ConcurrentMapas a key or value happen-before actions subsequent to the access or removal of that object from theConcurrentMapin another thread.- Since:
- 1.5
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description VputIfAbsent(K key, V value)If the specified key is not already associated with a value, associate it with the given value.booleanremove(Object key, Object value)Removes the entry for a key only if currently mapped to a given value.Vreplace(K key, V value)Replaces the entry for a key only if currently mapped to some value.booleanreplace(K key, V oldValue, V newValue)Replaces the entry for a key only if currently mapped to a given value.
-
-
-
Method Detail
-
putIfAbsent
V putIfAbsent(K key, V value)
If the specified key is not already associated with a value, associate it with the given value. This is equivalent to
except that the action is performed atomically.if (!map.containsKey(key)) return map.put(key, value); else return map.get(key);- Parameters:
key- key with which the specified value is to be associatedvalue- value to be associated with the specified key- Returns:
- the previous value associated with the specified key, or
nullif there was no mapping for the key. (Anullreturn can also indicate that the map previously associatednullwith the key, if the implementation supports null values.) - Throws:
UnsupportedOperationException- if theputoperation is not supported by this mapClassCastException- if the class of the specified key or value prevents it from being stored in this mapNullPointerException- if the specified key or value is null, and this map does not permit null keys or valuesIllegalArgumentException- if some property of the specified key or value prevents it from being stored in this map
-
remove
boolean remove(Object key, Object value)
Removes the entry for a key only if currently mapped to a given value. This is equivalent to
except that the action is performed atomically.if (map.containsKey(key) && map.get(key).equals(value)) { map.remove(key); return true; } else return false;- Parameters:
key- key with which the specified value is associatedvalue- value expected to be associated with the specified key- Returns:
trueif the value was removed- Throws:
UnsupportedOperationException- if theremoveoperation is not supported by this mapClassCastException- if the key or value is of an inappropriate type for this map (optional)NullPointerException- if the specified key or value is null, and this map does not permit null keys or values (optional)
-
replace
boolean replace(K key, V oldValue, V newValue)
Replaces the entry for a key only if currently mapped to a given value. This is equivalent to
except that the action is performed atomically.if (map.containsKey(key) && map.get(key).equals(oldValue)) { map.put(key, newValue); return true; } else return false;- Parameters:
key- key with which the specified value is associatedoldValue- value expected to be associated with the specified keynewValue- value to be associated with the specified key- Returns:
trueif the value was replaced- Throws:
UnsupportedOperationException- if theputoperation is not supported by this mapClassCastException- if the class of a specified key or value prevents it from being stored in this mapNullPointerException- if a specified key or value is null, and this map does not permit null keys or valuesIllegalArgumentException- if some property of a specified key or value prevents it from being stored in this map
-
replace
V replace(K key, V value)
Replaces the entry for a key only if currently mapped to some value. This is equivalent to
except that the action is performed atomically.if (map.containsKey(key)) { return map.put(key, value); } else return null;- Parameters:
key- key with which the specified value is associatedvalue- value to be associated with the specified key- Returns:
- the previous value associated with the specified key, or
nullif there was no mapping for the key. (Anullreturn can also indicate that the map previously associatednullwith the key, if the implementation supports null values.) - Throws:
UnsupportedOperationException- if theputoperation is not supported by this mapClassCastException- if the class of the specified key or value prevents it from being stored in this mapNullPointerException- if the specified key or value is null, and this map does not permit null keys or valuesIllegalArgumentException- if some property of the specified key or value prevents it from being stored in this map
-
-