快速失败 (fail-fast) 和安全失败 (fail-safe)

在上篇文章中有写到ArrayList 和Vector,期间在Add 方法中有出现modCount 变量,这个变量继承与AbstractList,解释为记录list 修改的次数,对于其理解不是太深入,因此特意记录一下。

1、快速失败:

是指在多线程访问情况下,使用迭代器遍历集合数据时,其他线程对集合有进行了修改,此时则会抛出
Concurrent Modification Exception异常。比如ArrayList 中的add()、remove(),clear()等方法。

原理:

迭代器在遍历时直接访问集合中的内容,并且在遍历过程中使用一个 modCount 变量。集合在被遍历期间如果元素数量发生变化,就会改变modCount的值。每次迭代器使用hashNext()/next()遍历下一个元素之前,都会检测modCount和expectedmodCount值是否相等,是的话就返回遍历;否则抛出异常ConcurrentModificationException,终止遍历。

缺点:

首先,异常的抛出条件是判断是 modCount=expectedmodCount 。如果集合发生变化时修改modCount值刚好又设置为了expectedmodCount值,则异常不会抛出。因此,不能依赖于这个异常是否抛出而进行并发操作的编程,这个异常只建议用于检测并发修改的bug。

源码分析:

在AbstractList中,有protected transient int modCount = 0 ,同时有一个私有的内部类

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值