Class IdentityMap

  • All Implemented Interfaces:
    java.io.Serializable, java.lang.Cloneable, java.util.Map, IterableMap

    public class IdentityMap
    extends AbstractHashedMap
    implements java.io.Serializable, java.lang.Cloneable
    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) $
    See Also:
    Serialized Form
    • Field Detail

      • serialVersionUID

        private static final long serialVersionUID
        Serialisation version
        See Also:
        Constant Field Values
    • Constructor Detail

      • 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:
        java.lang.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 capacity
        loadFactor - the load factor
        Throws:
        java.lang.IllegalArgumentException - if the initial capacity is less than one
        java.lang.IllegalArgumentException - if the load factor is less than zero
      • IdentityMap

        public IdentityMap​(java.util.Map map)
        Constructor copying elements from another map.
        Parameters:
        map - the map to copy
        Throws:
        java.lang.NullPointerException - if the map is null
    • Method Detail

      • hash

        protected int hash​(java.lang.Object key)
        Gets the hash code for the key specified. This implementation uses the identity hash code.
        Overrides:
        hash in class AbstractHashedMap
        Parameters:
        key - the key to get a hash code for
        Returns:
        the hash code
      • isEqualKey

        protected boolean isEqualKey​(java.lang.Object key1,
                                     java.lang.Object key2)
        Compares two keys for equals. This implementation uses ==.
        Overrides:
        isEqualKey in class AbstractHashedMap
        Parameters:
        key1 - the first key to compare
        key2 - the second key to compare
        Returns:
        true if equal by identity
      • isEqualValue

        protected boolean isEqualValue​(java.lang.Object value1,
                                       java.lang.Object value2)
        Compares two values for equals. This implementation uses ==.
        Overrides:
        isEqualValue in class AbstractHashedMap
        Parameters:
        value1 - the first value to compare
        value2 - the second value to compare
        Returns:
        true if equal by identity
      • createEntry

        protected AbstractHashedMap.HashEntry createEntry​(AbstractHashedMap.HashEntry next,
                                                          int hashCode,
                                                          java.lang.Object key,
                                                          java.lang.Object value)
        Creates an entry to store the data. This implementation creates an IdentityEntry instance.
        Overrides:
        createEntry in class AbstractHashedMap
        Parameters:
        next - the next entry in sequence
        hashCode - the hash code to use
        key - the key to store
        value - the value to store
        Returns:
        the newly created entry
      • clone

        public java.lang.Object clone()
        Clones the map without cloning the keys or values.
        Overrides:
        clone in class AbstractHashedMap
        Returns:
        a shallow clone
      • writeObject

        private void writeObject​(java.io.ObjectOutputStream out)
                          throws java.io.IOException
        Write the map out using a custom routine.
        Throws:
        java.io.IOException
      • readObject

        private void readObject​(java.io.ObjectInputStream in)
                         throws java.io.IOException,
                                java.lang.ClassNotFoundException
        Read the map in using a custom routine.
        Throws:
        java.io.IOException
        java.lang.ClassNotFoundException