全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

java 中modCount 详解及源码分析

modCount到底是干什么的呢

在ArrayList,LinkedList,HashMap等等的内部实现增,删,改中我们总能看到modCount的身影,modCount字面意思就是修改次数,但为什么要记录modCount的修改次数呢?

大家发现一个公共特点没有,所有使用modCount属性的全是线程不安全的,这是为什么呢?说明这个玩意肯定和线程安全有关系喽,那有什么关系呢

阅读源码,发现这玩意只有在本数据结构对应迭代器中才使用,以HashMap为例:

private abstract class HashIterator<E> implements Iterator<E> {
    Entry<K,V> next;    // next entry to return
    int expectedModCount;  // For fast-fail
    int index;       // current slot
    Entry<K,V> current;   // current entry

    HashIterator() {
      expectedModCount = modCount;
      if (size > 0) { // advance to first entry
        Entry[] t = table;
        while (index < t.length && (next = t[index++]) == null)
          ;
      }
    }

    public final boolean hasNext() {
      return next != null;
    }

    final Entry<K,V> nextEntry() {
      if (modCount != expectedModCount)
        throw new ConcurrentModificationException();
      Entry<K,V> e = next;
      if (e == null)
        throw new NoSuchElementException();

      if ((next = e.next) == null) {
        Entry[] t = table;
        while (index < t.length && (next = t[index++]) == null)
          ;
      }
      current = e;
      return e;
    }

    public void remove() {
      if (current == null)
        throw new IllegalStateException();
      if (modCount != expectedModCount)
        throw new ConcurrentModificationException();
      Object k = current.key;
      current = null;
      HashMap.this.removeEntryForKey(k);
      expectedModCount = modCount;
    }
  }

由以上代码可以看出,在一个迭代器初始的时候会赋予它调用这个迭代器的对象的mCount,如何在迭代器遍历的过程中,一旦发现这个对象的mcount和迭代器中存储的mcount不一样那就抛异常

好的,下面是这个的完整解释

Fail-Fast 机制

我们知道 java.util.HashMap 不是线程安全的,因此如果在使用迭代器的过程中有其他线程修改了map,那么将抛出ConcurrentModificationException,这就是所谓fail-fast策略。这一策略在源码中的实现是通过 modCount 域,modCount 顾名思义就是修改次数,对HashMap 内容的修改都将增加这个值,那么在迭代器初始化过程中会将这个值赋给迭代器的 expectedModCount。在迭代过程中,判断 modCount 跟 expectedModCount 是否相等,如果不相等就表示已经有其他线程修改了 Map:注意到 modCount 声明为 volatile,保证线程之间修改的可见性。

所以在这里和大家建议,当大家遍历那些非线程安全的数据结构时,尽量使用迭代器

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# java  # modCount  # modCount详解  # modCount分析  # Java中包装类介绍与其注意事项  # java实现字符串和日期类型相互转换的方法  # java计算给定字符串中出现次数最多的字母和该字母出现次数的方法  # java HashMap内部实现原理详解  # Java中基于maven实现zxing二维码功能  # Java将文件分割为多个子文件再将子文件合并成原始文件的示例  # java实现文件保存到本地的方法  # 详解Java中“==”与equals()的区别  # Java 散列存储详解及简单示例  # Java之Spring AOP 实现用户权限验证  # java Socket UDP实例详解  # 迭代  # 过程中  # 遍历  # 数据结构  # 这是  # 器中  # 这一  # 在这里  # 那就  # 中有  # 希望能  # 注意到  # 都将  # 为例  # 可以看出  # 什么呢  # 顾名思义  # 谢谢大家  # 会将  # 有什么关系 


相关文章: 高端网站建设与定制开发一站式解决方案 中企动力  历史网站制作软件,华为如何找回被删除的网站?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  c++ stringstream用法详解_c++字符串与数字转换利器  建站上市公司网站建设方案与SEO优化服务定制指南  如何快速搭建高效香港服务器网站?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  建站上传速度慢?如何优化加速网站加载效率?  网站制作价目表怎么做,珍爱网婚介费用多少?  手机网站制作与建设方案,手机网站如何建设?  免费视频制作网站,更新又快又好的免费电影网站?  开封网站制作公司,网络用语开封是什么意思?  三星网站视频制作教程下载,三星w23网页如何全屏?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  如何快速生成橙子建站落地页链接?  制作网站公司那家好,网络公司是做什么的?  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  如何选择适配移动端的WAP自助建站平台?  如何用PHP工具快速搭建高效网站?  宁波免费建站如何选择可靠模板与平台?  XML的“混合内容”是什么 怎么用DTD或XSD定义  建站之星如何快速解决建站难题?  建站之星各版本价格是多少?  网站好制作吗知乎,网站开发好学吗?有什么技巧?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  Android滚轮选择时间控件使用详解  如何解决ASP生成WAP建站中文乱码问题?  浅谈Javascript中的Label语句  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  江苏网站制作公司有哪些,江苏书法考级官方网站?  建站OpenVZ教程与优化策略:配置指南与性能提升  小建面朝正北,A点实际方位是否存在偏差?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  制作网站的基本流程,设计网站的软件是什么?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  如何使用Golang table-driven基准测试_多组数据测量函数效率  ,怎么用自己头像做动态表情包?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  建站之星伪静态规则如何正确配置?  建站之星与建站宝盒如何选择最佳方案?  如何通过虚拟主机快速搭建个人网站?  建站主机与虚拟主机有何区别?如何选择最优方案?  nginx修改上传文件大小限制的方法  音响网站制作视频教程,隆霸音响官方网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。