当前位置:   article > 正文

JDK1.8 ConcurrentHashMap的死循环bug_1.8 hashmap死循环

1.8 hashmap死循环

在JDK1.8版本中,ConcurrentHashMap中存在死循环bug,下面是bug重现代码:

package com.hiwe.demo.cache;

import java.util.concurrent.ConcurrentHashMap;

public class TestCache {
    public static void main(String[] args) {
        ConcurrentHashMap<String, Integer> map = new ConcurrentHashMap<>(16);
        map.computeIfAbsent(
                "AaAa",
                key -> {
                    return map.computeIfAbsent(
                            "BBBB",
                            key2 -> 42);
                }
        );
        System.out.println("程序完成");
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

执行以上代码,程序会进入死循环状态,导致CPU使用率暴涨。

bug原因:
因为"AaAa"和“BBBB”的hash值相同,会定位到用一个bucket中,这样就形成了CAS嵌套,产生死循环问题。具体的可以看源码分析。

解决:
禁止在向ConcurrentHashMap中嵌套执行computeIfAbsent/putIfAbsent操作。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/576485
推荐阅读
相关标签
  

闽ICP备14008679号