我是靠谱客的博主 敏感柚子,最近开发中收集的这篇文章主要介绍[ConcurrentHashMap] 1.computeIfAbsent嵌套使用会造成死循环 2.解决单线程下遍历过程中修改的问题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

 1)问题1

package org.example.testChm2;


import com.google.common.collect.Maps;

import java.util.Map;

/**
 * @author jianan
 * @date 2021/7/2 10:45:06
 */
public class TestChm2 {
	public static Map<String, String> testMap = Maps.newConcurrentMap();

	public static void main(String[] args) {
		System.out.println("AaAa".hashCode() + ":" + "BBBB".hashCode()); // 2031744:2031744


		get1("test");
	}

	public static String get1(String key) {
		return testMap.computeIfAbsent("AaAa", TestChm2::get2);
	}

	public static String get2(String key) {
		// 死循环代码(2次操作的是同一个Map)
		// BBBB与AaAa的HashCode相同,造成死循环
//		return testMap.computeIfAbsent("BBBB", k -> {
//			System.out.println("here------------------");
//			return "test";
//		});

		// 没有问题的代码
		String v = testMap.get("BBBB");
		if (v == null) {
			System.out.println("here------------------");
			return "test";
		}

		return v;
	}
}

/*
2031744:2031744
Exception in thread "main" java.lang.IllegalStateException: Recursive update
	at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1760)
	at org.example.testChm2.TestChm2.get2(TestChm2.java:28)
	at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1705)
	at org.example.testChm2.TestChm2.get1(TestChm2.java:23)
	at org.example.testChm2.TestChm2.main(TestChm2.java:19)

here------------------
 */

2)问题2  //  虽然是单线程环境下,但是遍历时又修改 ,依然会报错。用chm即可

package org.example.testmap;

import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ThreadLocalRandom;

public class Main4 {
    public static void main(String[] args) {
        Map<Integer, Integer> map = new HashMap<>();

        // 使用了这个则不会报错
        map = new ConcurrentHashMap<>();

        int i = 0;
        while (i++ < 1000) {
            map.put(i, 1);

            for (Integer key : map.keySet()) {
                map.put(ThreadLocalRandom.current().nextInt(5), 1);
                map.remove(key);
            }
        }

        System.out.println(map.size());
    }
}

/*
Exception in thread "main" java.util.ConcurrentModificationException
	at java.base/java.util.HashMap$HashIterator.nextNode(HashMap.java:1493)
	at java.base/java.util.HashMap$KeyIterator.next(HashMap.java:1516)
	at org.example.testmap.Main4.main(Main4.java:15)
 */

最后

以上就是敏感柚子为你收集整理的[ConcurrentHashMap] 1.computeIfAbsent嵌套使用会造成死循环 2.解决单线程下遍历过程中修改的问题的全部内容,希望文章能够帮你解决[ConcurrentHashMap] 1.computeIfAbsent嵌套使用会造成死循环 2.解决单线程下遍历过程中修改的问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(42)

评论列表共有 0 条评论

立即
投稿
返回
顶部