HashMap的死循环

历史背景

HashMap的死循环只是在JDK1.7中会出现。主要是HashMap自身的工作机制,再加上并发操作,从而会导致死循环的出现。

在JDK1.8以后,官方彻底地解决了这个问题。

数据插入原理

JDK1.7中HashMap插入数据的原理:
底层的数据存储结构:数据+链表
插入数据的方式:头插法

在这里插入图片描述

导致死循环的原因

还原并发场景下HashMap扩容导致的死循环问题:

  1. 线程启动
    在这里插入图片描述
  2. 开始扩容
    假设线程T2的时间片用完,进入休眠状态。线程T1开始执行扩容动作。一直到线程T1扩容完之后,线程T2才被唤醒。线程T1完成扩容之后的场景如下图:
    在这里插入图片描述
    当线程T1执行完成之后,线程T2恢复执行,死循环这时候就发生了:
    在这里插入图片描述
    A节点和B节点就形成了死循环。

解决方案

  1. 使用线程安全的ConcurrentHashMap来替代HashMap,推荐。
  2. 使用线程安全的Hashtable替代,性能低,不建议。
  3. 使用synchronized或Lock加锁,会影响性能,不建议。(相当于多线程排队执行)

总结

在这里插入图片描述
参考资料【Java面试】带你深入理解 为什么HashMap会产生死循环?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值