HashMap线程不安全的体现

HashMap1.7使用的是头插法,1.8后使用尾插法

链表头插法的会颠倒原来一个散列桶里面链表的顺序。在并发的时候原来的顺序被另外一个线程a颠倒了,而被挂起线程b恢复后拿扩容前的节点和顺序继续完成第一次循环后,又遵循a线程扩容后的链表顺序重新排列链表中的顺序,最终形成了环。

当两个线程分别对hashmap进行插入操作 并且引发了扩展的操作,在这种情况下采用头插法的话 重新扩展后的定位又是在同一个桶的话 那很容易导致成环 死循环出不来 最主要原因是null值的丢失。

如果采用尾插法的话null值不会丢失 就算是多线程导致扩展也不会导致死循环的情况出现 最多只是丢失一部分数据(如果是直接在尾部插入)

不安全总结

首先HashMap是线程不安全的,其主要体现:
1.在jdk1.7中,在多线程环境下,扩容时会造成环形链或数据丢失。
2.在jdk1.8中,在多线程环境下,会发生数据覆盖的情况。

详细转载自:
https://www.cnblogs.com/developer_chan/p/10450908.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值