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版本的这个问题在当前版本中已经得到解决,但理解这些问题的根源有助于我们更好地掌握数据结构和多线程编程的原理。
热门推荐
调包退货案件的法律适用与责任认定分析
臂丛神经炎 | 诊断与治疗
牙齿一咬合就疼怎么办
江苏盐城:“千亿级”绿色能源“碳路先锋” 打造全球新能源产业发展新高地
河南西峡:打造山茱萸基地 推进药旅融合发展
协议存款存在哪些潜在风险?这些潜在风险如何评估和应对?
协议存款存在哪些潜在风险?这些潜在风险如何评估和应对?
人伤调查岗位职责汇编(2篇)
韩国留学你不知道的换钱大攻略
硬核科普:真空的十层理解
拍摄星空时,这些相机设置要点你掌握了吗?
“驼背”的危害很可怕?“平背”更可怕!
小货车拉货需要办理哪些证件?注意事项有哪些?
COMSOL三维光子晶体能带计算
唇部干燥的护理方法&原因及应对方法!
买楼大忌!宁买4楼、14楼,也不买这“3个楼层”,它们都是标准的穷人房
白酒为什么不能点燃的原因有哪些
sigmoid函数到底是怎么形成的,然后其与逻辑回归的关系
深度学习中的神经网络初始化:为什么正态分布的标准差要设为1/sqrt(n_in)
遗书:合法效力与制作要点的深度解析
海洋生态灾害的成因有哪些?海洋灾害有哪些类型?
淄博旅游攻略:千年瓷都+烧烤节,这个夏天就去这里吧!
速度越快时间就越慢,所谓的“时间膨胀效应”到底该如何理解?
服务器脚本语言大盘点:10种主流语言详解
Redis 8种底层数据结构简介
Redis内存淘汰策略深度解析
冲刺高校之城,这些万亿GDP城市正在全力建大学丨教育大变革①
美国外观专利也能加速审查,这些条件和费用需提前了解
中药苦涩不再愁,轻松饮下有“技”可施
被人骚扰应如何通过法律来保护自己