HashMap 数据覆盖问题

本文探讨了HashMap在Java 1.7和1.8中因扩容和多线程导致的数据覆盖问题。在1.7中,线程A在插入时被挂起,线程B随后插入相同位置,A恢复后覆盖B的插入。在1.8中,虽然检查了哈希碰撞,但在多线程下仍存在覆盖风险。问题的根本原因是HashMap未加锁。另外,文章还提到了负载因子为0.75时,8个元素转红黑树的概率以及哈希搅动与16位的关系。
摘要由CSDN通过智能技术生成

阿粉今天就来谈谈这个,这个问题在 1.7 版本和 1.8 版本中都有,阿粉分别来说说

在说之前,咱们先要达成一个共识: HashMap 发生数据覆盖的问题,是在多线程环境 & 扩容下产生的,接下来咱们具体来看

jdk 1.7

	void transfer(Entry[] newTable, boolean rehash) {
     
        int newCapacity = newTable.length;  
        for (Entry<K,V> e : table) {
     
  
            while(null != e) {
     
                Entry<K,V> next = e.next;           
                if (rehash) {
     
                    e.hash = null == e.key ? 0 : hash(e.key);  
                }  
                int i = indexFor(e.hash
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值