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小时内与您取得联系。