java.util.ConcurrentModificationException 解决办法
前言:
在使用iterator.hasNext()操作迭代器的时候,如果此时迭代的对象发生改变,比如插入了新数据,或者有数据被删除。
则使用会报以下异常:
1
2
3
|
Java.util.ConcurrentModificationException
at java.util.HashMap$HashIterator.nextEntry(HashMap.java: 793 )
at java.util.HashMap$KeyIterator.next(HashMap.java: 828 )
|
例如以下程序(转自互联网):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
mport java.util.*;
public class Main
{
public static void main(String args[])
{
Main main = new Main();
main.test();
}
public void test()
{
Map bb = new HashMap();
bb.put( "1" , "wj" );
bb.put( "2" , "ry" );
Iterator it = bb.keySet().iterator();
while (it.hasNext()) {
Object ele = it.next();
bb.remove(ele); //wrong
}
System.out.println( "Success!" );
}
}
|
原因:Iterator做遍历的时候,HashMap被修改(bb.remove(ele), size-1),Iterator(Object ele=it.next())会检查HashMap的size,size发生变化,抛出错误ConcurrentModificationException。
解决办法:
1) 通过Iterator修改Hashtable
1
2
3
4
|
while (it.hasNext()) {
Object ele = it.next();
it.remove();
}
|
2) 根据实际程序,您自己手动给Iterator遍历的那段程序加锁,给修改HashMap的那段程序加锁。
3) 使用“ConcurrentHashMap”替换HashMap,ConcurrentHashMap会自己检查修改操作,对其加锁,也可针对插入操作。
1
|
import java.util.concurrent.*;
|
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/lipei1220/article/details/9028669