版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/EndTheme_Xin/article/details/83781106
直接上代码
ArrayList<Integer> list = new ArrayList<>();
{
list.add(1);
list.add(3);
list.add(2);
list.add(4);
list.add(5);
list.add(6);
list.add(7);
}
@Test
public void testRemoveListElement() {
for (int i : list) {
if (i % 2 == 0) {
list.remove(i);
}
}
// java.util.ConcurrentModificationException
}
目的是想删去集合中所有的偶数。
但是运行却抛了ConcurrentModificationException错误
分析原因
根据报错的信息,可以看到是因为modCount != expectedModCount导致的。
再查看859行,发现是在next()方法调用的checkForComodification();
然后我们再到ArrayList中查看remove的源码,发现删除一个元素的时候会做modCount++操作。
解决方案一
用多一个newList,添加符合条件的元素(即原判断条件取反),最后返回这个newList即可
@Test
public void testRemoveListElement2() {
ArrayList<Integer> newList = new ArrayList<>();
for (int i : list) {
// 条件取反
if (i % 2 != 0) {
newList.add(i);
}
}
}
解决方案二
不适用foreach的形式,使用fori
@Test
public void testRemoveListElement1() {
for (int i = 0; i < list.size(); i++) {
if (list.get(i) % 2 == 0) {
list.remove(i);
i--;
}
}
}
同时这里要注意每次删除元素要把计数的i往前移一个,即i--;