出现java.util.ConcurrentModificationException 的代码如下:
for (Iterator<Map.Entry<Long, String>> iterator = map.entrySet()
.iterator(); iterator.hasNext();) {
Map.Entry<Long, String> entry = iterator.next();
if (...){
map.remove(entry.getKey());
}
}
在Map执行remove之后,iterator执行next之后报java.util.ConcurrentModificationException异常
网上的解释为:
Iterator 是工作在一个独立的线程中,并且拥有一个 mutex 锁。 Iterator 被创建之后会建立一个指向原来对象的单链索引表,当原来的对象数量发生变化时,这个索引表的内容不会同步改变,所以当索引指针往后移动的时候就找不到要迭代的对象,所以按照 fail-fast 原则 Iterator 会马上抛出 java.util.ConcurrentModificationException 异常。
所以 Iterator 在工作的时候是不允许被迭代的对象被改变的。但你可以使用 Iterator 本身的方法 remove() 来删除对象, Iterator.remove() 方法会在删除当前迭代对象的同时维护索引的一致性。
所以代码中的
map.remove(entry.getKey());
应改为
iterator.remove();
本文深入探讨了在Java并发编程中遇到的ConcurrentModificationException问题,特别是当Map执行remove操作后,使用Iterator进行遍历时抛出此异常的情况。通过分析原因,提出了解决方案,即在删除元素时使用Iterator的remove方法代替直接调用Map的remove方法。
422

被折叠的 条评论
为什么被折叠?



