Concurrent Hash Map
Concurrent Hash Map
comes when you want to modify the Collection object while using iterator to go through with all its
element.
Java 1.5 has introduced java.util.concurrent package with Collection classes implementations that allow
you to modify your collection object at runtime.
ConcurrentHashMap is the class that is similar to HashMap but works fine when you try to modify your
map at runtime.
Lets run a sample program to explore this:
ConcurrentHashMapExample.java
1 package com.journaldev.util;
2
3 import java.util.HashMap;
4 import java.util.Iterator;
5 import java.util.Map;
6 import java.util.concurrent.ConcurrentHashMap;
7
8 public class ConcurrentHashMapExample {
9
10 public static void main(String[] args) {
11
12
//ConcurrentHashMap
13
14
myMap.put("1", "1");
15
myMap.put("2", "1");
16
myMap.put("3", "1");
17
myMap.put("4", "1");
18
myMap.put("5", "1");
19
myMap.put("6", "1");
20
21
Iterator<String> it = myMap.keySet().iterator();
22
23
while(it.hasNext()){
24
25
26
27
28
29
//HashMap
30
31
myMap.put("1", "1");
32
myMap.put("2", "1");
33
myMap.put("3", "1");
34
myMap.put("4", "1");
35
myMap.put("5", "1");
36
myMap.put("6", "1");
37
38
39
40
while(it1.hasNext()){
41
42
43
44
45 }
46
47}
When we try to run the above class, output is
1 ConcurrentHashMap before iterator: {1=1, 5=1, 6=1, 3=1, 4=1, 2=1}
2 ConcurrentHashMap after iterator: {1=1, 3new=new3, 5=1, 6=1, 3=1, 4=1, 2=1}
3 HashMap before iterator: {3=1, 2=1, 1=1, 6=1, 5=1, 4=1}
4 Exception in thread "main" java.util.ConcurrentModificationException
5
at java.util.HashMap$HashIterator.nextEntry(HashMap.java:793)
at java.util.HashMap$KeyIterator.next(HashMap.java:828)
at com.test.ConcurrentHashMapExample.main(ConcurrentHashMapExample.java:44)
Looking at the output, its clear that ConcurrentHashMap takes care of any new entry in the map
whereas HashMap throws ConcurrentModificationException.
Lets look at the exception stack trace closely. The statement that has thrown Exception is:
1
It means that the new entry got inserted in the HashMap but Iterator is failing. Actually Iterator on
Collection objects are fail-fast i.e any modification in the structure or the number of entry in the
collection object will trigger this exception thrown by iterator.
So How does iterator knows that there has been some modification in the HashMap. We have taken the
set of keys from HashMap once and then iterating over it.
HashMap contains a variable to count the number of modifications and iterator use it when you call its
next() function to get the next entry.
HashMap.java
1 /**
2
*/
Now to prove above point, lets change the code a little bit to come out of the iterator loop when we
insert the new extry. All we need to do is add a break statement after the put call.
1 if(key.equals("3")){
2
myMap.put(key+"new", "new3");
break;
Now execute the modified code and the output will be:
1 ConcurrentHashMap before iterator: {1=1, 5=1, 6=1, 3=1, 4=1, 2=1}
2 ConcurrentHashMap after iterator: {1=1, 3new=new3, 5=1, 6=1, 3=1, 4=1, 2=1}
3 HashMap before iterator: {3=1, 2=1, 1=1, 6=1, 5=1, 4=1}
4 HashMap after iterator: {3=1, 2=1, 1=1, 3new=new3, 6=1, 5=1, 4=1}
Finally, what if we wont add a new entry but update the existing key-value pair. Will it throw exception?
Change the code in the original program and check yourself.
1 //myMap.put(key+"new", "new3");
2 myMap.put(key, "new3");