Class IdentityMap
java.lang.Object
java.util.AbstractMap
org.apache.commons.collections.map.AbstractHashedMap
org.apache.commons.collections.map.IdentityMap
- All Implemented Interfaces:
Serializable,Cloneable,Map,IterableMap
A
Map implementation that matches keys and values based
on == not equals().
This map will violate the detail of various Map and map view contracts. As a general rule, don't compare this map to other maps.
Note that IdentityMap is not synchronized and is not thread-safe.
If you wish to use this map from multiple threads concurrently, you must use
appropriate synchronization. The simplest approach is to wrap this map
using Collections.synchronizedMap(Map). This class may throw
exceptions when accessed by concurrent threads without synchronization.
- Since:
- Commons Collections 3.0
- Version:
- $Revision: 646777 $ $Date: 2008-04-10 14:33:15 +0200 (Thu, 10 Apr 2008) $
- Author:
- java util HashMap, Stephen Colebourne
- See Also:
-
Nested Class Summary
Nested ClassesNested classes/interfaces inherited from class org.apache.commons.collections.map.AbstractHashedMap
AbstractHashedMap.EntrySet, AbstractHashedMap.EntrySetIterator, AbstractHashedMap.HashEntry, AbstractHashedMap.HashIterator, AbstractHashedMap.HashMapIterator, AbstractHashedMap.KeySet, AbstractHashedMap.KeySetIterator, AbstractHashedMap.Values, AbstractHashedMap.ValuesIteratorNested classes/interfaces inherited from class java.util.AbstractMap
AbstractMap.SimpleEntry<K extends Object,V extends Object>, AbstractMap.SimpleImmutableEntry<K extends Object, V extends Object> -
Field Summary
Fields inherited from class org.apache.commons.collections.map.AbstractHashedMap
data, DEFAULT_CAPACITY, DEFAULT_LOAD_FACTOR, DEFAULT_THRESHOLD, entrySet, GETKEY_INVALID, GETVALUE_INVALID, keySet, loadFactor, MAXIMUM_CAPACITY, modCount, NO_NEXT_ENTRY, NO_PREVIOUS_ENTRY, NULL, REMOVE_INVALID, SETVALUE_INVALID, size, threshold, values -
Constructor Summary
ConstructorsConstructorDescriptionConstructs a new empty map with default size and load factor.IdentityMap(int initialCapacity) Constructs a new, empty map with the specified initial capacity.IdentityMap(int initialCapacity, float loadFactor) Constructs a new, empty map with the specified initial capacity and load factor.IdentityMap(Map map) Constructor copying elements from another map. -
Method Summary
Modifier and TypeMethodDescriptionclone()Clones the map without cloning the keys or values.protected AbstractHashedMap.HashEntrycreateEntry(AbstractHashedMap.HashEntry next, int hashCode, Object key, Object value) Creates an entry to store the data.protected intGets the hash code for the key specified.protected booleanisEqualKey(Object key1, Object key2) Compares two keys for equals.protected booleanisEqualValue(Object value1, Object value2) Compares two values for equals.Methods inherited from class org.apache.commons.collections.map.AbstractHashedMap
addEntry, addMapping, calculateNewCapacity, calculateThreshold, checkCapacity, clear, containsKey, containsValue, convertKey, createEntrySetIterator, createKeySetIterator, createValuesIterator, destroyEntry, doReadObject, doWriteObject, ensureCapacity, entryHashCode, entryKey, entryNext, entrySet, entryValue, equals, get, getEntry, hashCode, hashIndex, init, isEmpty, keySet, mapIterator, put, putAll, remove, removeEntry, removeMapping, reuseEntry, size, toString, updateEntry, valuesMethods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.util.Map
compute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll
-
Constructor Details
-
IdentityMap
public IdentityMap()Constructs a new empty map with default size and load factor. -
IdentityMap
public IdentityMap(int initialCapacity) Constructs a new, empty map with the specified initial capacity.- Parameters:
initialCapacity- the initial capacity- Throws:
IllegalArgumentException- if the initial capacity is less than one
-
IdentityMap
public IdentityMap(int initialCapacity, float loadFactor) Constructs a new, empty map with the specified initial capacity and load factor.- Parameters:
initialCapacity- the initial capacityloadFactor- the load factor- Throws:
IllegalArgumentException- if the initial capacity is less than oneIllegalArgumentException- if the load factor is less than zero
-
IdentityMap
Constructor copying elements from another map.- Parameters:
map- the map to copy- Throws:
NullPointerException- if the map is null
-
-
Method Details
-
hash
Gets the hash code for the key specified. This implementation uses the identity hash code.- Overrides:
hashin classAbstractHashedMap- Parameters:
key- the key to get a hash code for- Returns:
- the hash code
-
isEqualKey
Compares two keys for equals. This implementation uses==.- Overrides:
isEqualKeyin classAbstractHashedMap- Parameters:
key1- the first key to comparekey2- the second key to compare- Returns:
- true if equal by identity
-
isEqualValue
Compares two values for equals. This implementation uses==.- Overrides:
isEqualValuein classAbstractHashedMap- Parameters:
value1- the first value to comparevalue2- the second value to compare- Returns:
- true if equal by identity
-
createEntry
protected AbstractHashedMap.HashEntry createEntry(AbstractHashedMap.HashEntry next, int hashCode, Object key, Object value) Creates an entry to store the data. This implementation creates an IdentityEntry instance.- Overrides:
createEntryin classAbstractHashedMap- Parameters:
next- the next entry in sequencehashCode- the hash code to usekey- the key to storevalue- the value to store- Returns:
- the newly created entry
-
clone
Clones the map without cloning the keys or values.- Overrides:
clonein classAbstractHashedMap- Returns:
- a shallow clone
-