集合中的modCount属性

modCount:记录当前集合被修改的次数
1)添加  2)删除
这两个操作都会影响元素的个数

当我们使用迭代器或者foreach遍历时,如果你在foreach遍历时,会自动调用迭代器的迭代方法
此时在遍历过程中调用了集合的add,remove方法时,modCount就会改变
而迭代器记录的modCount是开始迭代之前的,如果两个不一致就会报异常:ConcurrentModificationException
说明有两个线路/线程同时操作集合。这种操作有风险,为了保证结果的正确性,避免这样的情况发生,
一旦发现modCount与exceptedModCount不一致,立即报错,也就是fail-fast机制


此类的iterator 和 listIterator 方法返回的迭代器是快速失败的
在创建迭代器之后,除非通过迭代器自身的remove或add方法从结构上对列表进行修改
否则在任何时间以任何方式对列表进行修改,迭代器都会抛出ConcurrentModificationException异常
因此,面对并发的修改,迭代器很快就会完全失败
而不是冒着在将来某个不确定时间发生任意不确定行为的风险


HashMap中有引入一个fail-fast的概念,目的是避免高并发读写造成的数据错乱的隐患
并不是只有在多线程的情况下才会发生ConcurrentModificationException
单线程错误案例
 

HashMap m = new HashMap();
m.put("key1", "value2");
m.put("key2", "value2");
for (String key: m.keySet()) {
    if (key.equals("key2")) {
        m.remove(key);
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值