java.util.ConcurrentModificationException 解决办法

在使用iterator.hasNext()操作迭代器的时候,如果此时迭代的对象发生改变,比如插入了新数据,或者有数据被删除。

则使用会报以下异常:
Java.util.ConcurrentModificationException
        at java.util.HashMap$HashIterator.nextEntry(HashMap.java:793)
        at java.util.HashMap$KeyIterator.next(HashMap.java:828)

例如以下程序(转自互联网):

  1. mport java.util.*;
  2. public class Main
  3. {
  4. public static void main(String args[])
  5. {
  6. Main main = new Main();
  7. main.test();
  8. }
  9. public void test()
  10. {
  11. Map bb = new HashMap();
  12. bb.put("1", "wj");
  13. bb.put("2", "ry");
  14. Iterator it = bb.keySet().iterator();
  15. while(it.hasNext()) {
  16. Object ele = it.next();
  17. bb.remove(ele);    //wrong
  18. }
  19. System.out.println("Success!");
  20. }
  21. }

原因:Iterator做遍历的时候,HashMap被修改(bb.remove(ele), size-1),Iterator(Object ele=it.next())会检查HashMap的size,size发生变化,抛出错误ConcurrentModificationException。

解决办法:

1) 通过Iterator修改Hashtable
while(it.hasNext()) {
Object ele = it.next();
            it.remove();
}

2) 根据实际程序,您自己手动给Iterator遍历的那段程序加锁,给修改HashMap的那段程序加锁。

3) 使用“ConcurrentHashMap”替换HashMap,ConcurrentHashMap会自己检查修改操作,对其加锁,也可针对插入操作。
import java.util.concurrent.*;

上一篇:【Avalon】factory


下一篇:spring源码分析之spring-messaging模块详解