Class HashMap<K,V>
- Type Parameters:
K- the type of keys maintained by this mapV- the type of mapped values
- All Implemented Interfaces:
Serializable,Cloneable,Map<K,V>
- Direct Known Subclasses:
LinkedHashMap
public class HashMap<K,V> extends AbstractMap<K,V> implements Cloneable, Serializable
Map. All optional operations are supported.
All elements are permitted as keys or values, including null.
Note that the iteration order for HashMap is non-deterministic. If you want
deterministic iteration, use LinkedHashMap.
Note: the implementation of HashMap is not synchronized.
If one thread of several threads accessing an instance modifies the map
structurally, access to the map needs to be synchronized. A structural
modification is an operation that adds or removes an entry. Changes in
the value of an entry are not structural changes.
The Iterator created by calling the iterator method
may throw a ConcurrentModificationException if the map is structurally
changed while an iterator is used to iterate over the elements. Only the
remove method that is provided by the iterator allows for removal of
elements during iteration. It is not possible to guarantee that this
mechanism works in all cases of unsynchronized concurrent modification. It
should only be used for debugging purposes.
- See Also:
- Serialized Form
-
Nested Class Summary
Nested classes/interfaces inherited from class java.util.AbstractMap
AbstractMap.SimpleEntry<K,V>, AbstractMap.SimpleImmutableEntry<K,V> -
Constructor Summary
Constructors Constructor Description HashMap()Constructs a new emptyHashMapinstance.HashMap(int capacity)Constructs a newHashMapinstance with the specified capacity.HashMap(int capacity, float loadFactor)Constructs a newHashMapinstance with the specified capacity and load factor.HashMap(Map<? extends K,? extends V> map)Constructs a newHashMapinstance containing the mappings from the specified map. -
Method Summary
Modifier and Type Method Description voidclear()Removes all mappings from this hash map, leaving it empty.Objectclone()Returns a shallow copy of this map.booleancontainsKey(Object key)Returns whether this map contains the specified key.booleancontainsValue(Object value)Returns whether this map contains the specified value.Set<Map.Entry<K,V>>entrySet()Returns a set containing all of the mappings in this map.Vget(Object key)Returns the value of the mapping with the specified key.booleanisEmpty()Returns whether this map is empty.Set<K>keySet()Returns a set of the keys contained in this map.Vput(K key, V value)Maps the specified key to the specified value.voidputAll(Map<? extends K,? extends V> map)Copies all the mappings in the specified map to this map.Vremove(Object key)Removes the mapping with the specified key from this map.intsize()Returns the number of elements in this map.Collection<V>values()Returns a collection of the values contained in this map.Methods inherited from class java.util.AbstractMap
equals, hashCode, toString
-
Constructor Details
-
HashMap
public HashMap()Constructs a new emptyHashMapinstance. -
HashMap
public HashMap(int capacity)Constructs a newHashMapinstance with the specified capacity.- Parameters:
capacity- the initial capacity of this hash map.- Throws:
IllegalArgumentException- when the capacity is less than zero.
-
HashMap
public HashMap(int capacity, float loadFactor)Constructs a newHashMapinstance with the specified capacity and load factor.- Parameters:
capacity- the initial capacity of this hash map.loadFactor- the initial load factor.- Throws:
IllegalArgumentException- when the capacity is less than zero or the load factor is less or equal to zero or NaN.
-
HashMap
Constructs a newHashMapinstance containing the mappings from the specified map.- Parameters:
map- the mappings to add.
-
-
Method Details
-
clone
Returns a shallow copy of this map.- Overrides:
clonein classAbstractMap<K,V>- Returns:
- a shallow copy of this map.
-
isEmpty
public boolean isEmpty()Returns whether this map is empty. -
size
public int size()Returns the number of elements in this map. -
get
Returns the value of the mapping with the specified key. -
containsKey
Returns whether this map contains the specified key.- Specified by:
containsKeyin interfaceMap<K,V>- Overrides:
containsKeyin classAbstractMap<K,V>- Parameters:
key- the key to search for.- Returns:
trueif this map contains the specified key,falseotherwise.
-
containsValue
Returns whether this map contains the specified value.- Specified by:
containsValuein interfaceMap<K,V>- Overrides:
containsValuein classAbstractMap<K,V>- Parameters:
value- the value to search for.- Returns:
trueif this map contains the specified value,falseotherwise.
-
put
Maps the specified key to the specified value. -
putAll
Copies all the mappings in the specified map to this map. These mappings will replace all mappings that this map had for any of the keys currently in the given map. -
remove
Removes the mapping with the specified key from this map. -
clear
public void clear()Removes all mappings from this hash map, leaving it empty. -
keySet
Returns a set of the keys contained in this map. The set is backed by this map so changes to one are reflected by the other. The set does not support adding. -
values
Returns a collection of the values contained in this map. The collection is backed by this map so changes to one are reflected by the other. The collection supports remove, removeAll, retainAll and clear operations, and it does not support add or addAll operations.This method returns a collection which is the subclass of AbstractCollection. The iterator method of this subclass returns a "wrapper object" over the iterator of map's entrySet(). The
sizemethod wraps the map's size method and thecontainsmethod wraps the map's containsValue method.The collection is created when this method is called for the first time and returned in response to all subsequent calls. This method may return different collections when multiple concurrent calls occur, since no synchronization is performed.
-
entrySet
Returns a set containing all of the mappings in this map. Each mapping is an instance ofMap.Entry. As the set is backed by this map, changes in one will be reflected in the other.
-