JAVA--遍历List删除元素报ConcurrentModificationException

版权声明:本文为博主原创文章,未经博主允许不得转载。 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--;

猜你喜欢

转载自blog.csdn.net/EndTheme_Xin/article/details/83781106