HashMap1.7版本扩容时的死循环问题详解
创作时间:
作者:
@小白创作中心
HashMap1.7版本扩容时的死循环问题详解
引用
1
来源
1.
https://www.cnblogs.com/blogzero/p/18232672
HashMap是Java中非常重要的数据结构之一,在不同版本中针对多线程环境下的性能和安全性进行了多次优化。本文将通过代码分析和图解的方式,详细讲解HashMap1.7版本在多线程环境下扩容时使用头插法可能导致的死循环问题,并对比1.8版本中采用尾插法的改进。
1. 概述
在HashMap1.7版本中,扩容时采用的是头插法转移节点。在多线程并发的情况下,这种做法可能会导致链表死循环的问题。而在HashMap1.8版本中,这个问题通过改用尾插法得到了解决。
2. 问题分析
假设有两个线程,线程1和线程2,同时对HashMap进行put操作并触发了扩容。下面是扩容时节点转移的关键代码:
void transfer(Entry[] newTable) {
Entry[] src = table;
int newCapacity = newTable.length;
for (int j = 0; j < src.length; j++) {
Entry<K,V> e = src[j];
if (e != null) {//两个线程都先进入if
src[j] = null;
do {
Entry<K,V> next = e.next;
int i = indexFor(e.hash, newCapacity);
e.next = newTable[i]; //线程1 这里还没执行 停下
newTable[i] = e;
e = next;
} while (e != null);
}
}
}
线程1和线程2都进入if语句后,线程1在上述代码注释的地方暂停。此时的变量指针状态如下图所示:
线程2获得CPU资源并继续执行:
- 线程2执行完第一轮循环后:
- 线程2执行完第二轮循环后:
此时线程2暂停,轮到线程1继续执行。由于线程1中E变量指向a节点,next变量指向b节点,所以:
线程1继续执行被中断的代码:
void transfer(Entry[] newTable) {
Entry[] src = table;
int newCapacity = newTable.length;
for (int j = 0; j < src.length; j++) {
Entry<K,V> e = src[j];
if (e != null) {//两个线程都先进入if
src[j] = null;
do {
Entry<K,V> next = e.next;
int i = indexFor(e.hash, newCapacity);
e.next = newTable[i]; //线程1刚才在这里停下,所以现在从这一句代码开始执行
newTable[i] = e;
e = next;
} while (e != null);
}
}
}
执行完之后,链表结构变为:
此时,a节点的next指针指向了自己,形成了一个死循环。
3. 解决方案
在HashMap1.8版本中,通过改用尾插法解决了这个问题。尾插法确保了在多线程环境下,即使有线程切换,也不会导致链表结构的破坏。
总结
通过这个例子,我们可以看到HashMap在不同版本中的优化历程。虽然HashMap1.7版本的这个问题在当前版本中已经得到解决,但理解这些问题的根源有助于我们更好地掌握数据结构和多线程编程的原理。
热门推荐
钓鲫鱼的技巧和方法
详解卡络磺钠:从注射技巧到特殊人群用药指导
女性也需要读《孙子兵法》:四大兵法原则的现实启示
投资战略全攻略:从目标设定到风险管理
孙子兵法三大战略思维:如何在竞争中制胜
《孙子兵法》里的智慧:女性必备的生活与职场指南
五大染发技巧,让染发更有层次感
科技狠活看考古,纪录片《星空瞰华夏》第二季上线了
微纪录片创作之门向大众敞开
豆瓣评分9.0+,10部不看后悔的顶级纪录片!
王者荣耀貂蝉追踪按键设置攻略:提升战斗效率的关键技巧
《王者荣耀》追踪按键神配置,你get了吗?
如何选择合适的出国研学游学机构
“王海大队”再创佳绩,歼-20展雄风
王海大队:从“空中拼刺刀”到歼-20时代的英雄传奇
王海大队:从“空中拼刺刀”到信息化作战的英雄传承
王海大队:从“空中拼刺刀”到“威龙编队”的传奇
西双版纳冬季旅游:早晚温差大,这样搭配最适宜
西双版纳:热带雨林里的民族风与现代时尚混搭
西双版纳雨林探险:如何选择合适的衣物与装备
避寒首选西双版纳:冬季旅游攻略详解
个税优惠全解析:从专项扣除到合规筹划
真心话大冒险:聚会游戏最佳选择
情人节必备:情侣专属真心话大冒险
《全民枪战2》新手速成秘籍
丑柑粑粑柑傻傻分不清?教你一眼辨识两种日本柑橘
从眼神到关心:男生暗恋时的四大行为特征
经济不景气,老百姓如何在消费方面省钱
萨赫勒地区粮食危机:世界粮食计划署紧急援助行动
QQ回执单号:守护你的隐私安全