博客
关于我
Java高级之LinkedList的ListIterator迭代器
阅读量:257 次
发布时间:2019-03-01

本文共 641 字,大约阅读时间需要 2 分钟。

ListIterator在Java中用于遍历和操作集合,通过维护modCount和expectedModCount实现快速失败机制,确保在集合修改时立即报错。以下是详细解析:

  • 快速失败机制:ListIterator通过检查modCount和expectedModCount来检测集合是否被修改。modCount记录集合的修改次数,而expectedModCount记录迭代器的修改次数。一旦两者不一致,迭代器抛出ConcurrentModificationException,停止进一步操作。

  • next()方法的工作流程

    • 检查modCount:确保迭代器状态一致。
    • 判断是否有下一个元素:没有则抛出NoSuchElementException。
    • 保存当前节点:返回其内容。
    • 更新next指针:指向下一个节点。
    • 增加索引:nextIndex加1。
  • 多线程环境下的应用:在多线程中,若一个线程修改集合,另一个线程遍历,迭代器会检测到modCount变化,抛出异常,避免数据不一致。

  • 内部操作方法:使用迭代器的remove()或add()方法进行操作,可以确保modCount和expectedModCount同步,避免异常。

  • 性能考量:虽然内部操作影响性能,但确保了迭代器的正确性,是设计的必要牺牲。

  • 总结:ListIterator通过维护modCount和expectedModCount,实现了快速失败机制,确保迭代器在多线程或集合修改时的健壮性,是Java集合设计中的重要特性。

    转载地址:http://djkx.baihongyu.com/

    你可能感兴趣的文章
    MySQL InnoDB引擎的锁机制详解
    查看>>
    Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
    查看>>
    mysql InnoDB数据存储引擎 的B+树索引原理
    查看>>
    mysql innodb通过使用mvcc来实现可重复读
    查看>>
    mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
    查看>>
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    Mysql join原理
    查看>>
    MySQL Join算法与调优白皮书(二)
    查看>>
    Mysql order by与limit混用陷阱
    查看>>
    Mysql order by与limit混用陷阱
    查看>>
    mysql order by多个字段排序
    查看>>
    MySQL Order By实现原理分析和Filesort优化
    查看>>
    mysql problems
    查看>>
    mysql replace first,MySQL中处理各种重复的一些方法
    查看>>
    MySQL replace函数替换字符串语句的用法(mysql字符串替换)
    查看>>
    mysql replace用法
    查看>>
    Mysql Row_Format 参数讲解
    查看>>
    mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
    查看>>
    MySQL Server 5.5安装记录
    查看>>
    mysql server has gone away
    查看>>