Over a million developers have joined DZone.
{{announcement.body}}
{{announcement.title}}

Difference Between HashMap and IdentityHashMap

DZone's Guide to

Difference Between HashMap and IdentityHashMap

Most of the time I use HashMap whenever a map kinda object is needed. When reading some blog I came across IdentityHashMap in Java.

· Java Zone
Free Resource

Find your next Integration job at DZone Jobs. See jobs focused on integration, or create your profile and have the employers come to you!

Most of the time I use HashMap whenever a map kinda object is needed. When reading some blog I came across IdentityHashMap in Java. It is good to understand the differences between the two because you never know when you will see them flying across your code and you trying to find out why is  this kinda Map is used here.

IdentityHashMap as name suggests uses the equality operator(==) for comparing the keys. So when you put any Key Value pair in it the Key Object is compared using == operator.

 import java.util.HashMap; import java.util.IdentityHashMap; import java.util.Map;public class IdentityMapDemo {public static void main(String[] args) { Map identityMap = new IdentityHashMap(); Map hashMap = new HashMap(); identityMap.put("a", 1); identityMap.put(new String("a"), 2); identityMap.put("a", 3);hashMap.put("a", 1); hashMap.put(new String("a"), 2); hashMap.put("a", 3);System.out.println("Identity Map KeySet Size :: " +  identityMap.keySet().size()); System.out.println("Hash Map KeySet Size :: " + hashMap.keySet().size()); } } 

On the other hand HashMap uses equals method to determine the uniqueness of the Key.

k1.equals(k2) 

instead of equality operator.

When you run the above code the result will be

Identity Map KeySet Size :: 2Hash Map KeySet Size :: 1

The Keysize of Identity Map is 2 because here a and new String(“a”) are considered two different Object. The comparison is done using == operator.

For HashMap the keySize is 1 because K1.equals(K2) returns true for all three Keys and hence it keep on removing the old value and updating it with the new one.

These both Maps will behave in same manner if they are used for Keys which are user defined Object and doesn’t overrides equals method.

From http://himanshugpt.wordpress.com/2010/03/24/difference-between-hashmap-and-identityhashmap/

Find your next Integration job at DZone Jobs. See jobs focused on integration, or create your profile and have the employers come to you!

Topics:
java

Opinions expressed by DZone contributors are their own.

THE DZONE NEWSLETTER

Dev Resources & Solutions Straight to Your Inbox

Thanks for subscribing!

Awesome! Check your inbox to verify your email so you can start receiving the latest in tech news and resources.

X

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}