关于集合中的并发修改异常的一些见解 java.util.ConcurrentModificationException

本文详细探讨了Java中的并发修改异常`java.util.ConcurrentModificationException`,指出这种异常不仅出现在多线程环境中,单线程程序中也可能遇到。分析了异常产生的原因,特别是`modCount`和`expectedModCount`的角色。文章通过示例代码解释了为何在迭代过程中调用`remove()`方法会导致异常,并提出在迭代中使用迭代器自身的`remove()`方法可以避免这个问题。同时,文章讨论了删除不同位置元素时异常表现的差异,并邀请读者对其他集合类的类似行为进行分析。
摘要由CSDN通过智能技术生成

java.util.ConcurrentModificationException叫做并发修改异常

在对集合的学习中有个例子:看如下代码,注意红色字体处

public class TestArrayList {
    public static void main(String[] args) {
        ArrayList<String> list = new ArrayList<String>();
        list.add("张三");
        list.add("李四");
        list.add("王五");
        list.add("麻子");
        Iterator<String> iterator = list.iterator();
        while (iterator.hasNext()) {
            String s = iterator.next();
            System.out.println(s);
            if (s.equals("李四")) {
                list.remove("李四");
            }
        }
    }
}

运行改代码的时候就会出现java.util.ConcurrentModificationException,既然叫并发修改异常,那为什么会出现在单线程程序中呢?分析如下,调试过程中顺便看下一些方法的源码


先看一下Iterator类,此类是ArrayList的内部类,用来对集合元素进行迭代的  

该类中,hasNext()方法用来判断是否还有下一个元素,next用来获取下一个元素,remove用来删除当前元素,成员变

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值