在开发中,有时需要将多个Map合并成一个Map,接下来就举例说明:
我的使用场景:以map2中已经存在的key的值为准
Map<String, Object> map1 = new HashMap<>();
map1.put("A", 1);
map1.put("B", 2);
map1.put("C", 5);
Map map2 = new HashMap<>();
map2.put("C", 3);
map2.put("D", 4);
// 合并两个Map
map2.put("A", map1.get("A"));
map2.put("B", map1.get("B"));
map2.put("C", map1.get("C"));
System.out.println(map2);
输出结果为:
{A=1, B=2, C=5, D=4}
这个结果不是我想要的!
putAll()
方法map2.putAll(map1);
System.out.println(map2);
输出结果为:
{A=1, B=2, C=5, D=4}
这个结果不是我想要的!
map1.forEach((k, v) -> map2.merge(k, v, (v1, v2) -> v1));
System.out.println(map2);
输出结果为:
{A=1, B=2, C=3, D=4}
从结果看到时实现了,但是在实际业务使用过程中,会出现死循环的问题如下:
Handler dispatch failed; nested exception is java.lang.StackOverflowError
经过查找,StackOverflowError
栈内存溢出
StackOverflowError 是一个java中常出现的错误:在jvm运行时的数据区域中有一个java虚拟机栈,当执行java方法时会进行压栈弹栈的操作。在栈中会保存局部变量,操作数栈,方法出口等等。jvm规定了栈的最大深度,当执行时栈的深度大于了规定的深度,就会抛出StackOverflowError错误。
简单来说就是递归死循环,踩坑。。。。。。。。
public static <K, V> Map<K, V> mergeMaps(Map<K, V> map1, Map<K, V> map2) {
Map<K, V> result = new HashMap<>(map1);
for (Map.Entry<K, V> entry : map2.entrySet()) {
K key = entry.getKey();
V value = entry.getValue();
if (value != null) {
result.put(key, value);
} else if (!result.containsKey(key)) {
result.put(key, null);
}
}
return result;
}
Map map = mergeMaps(map1,map2);
System.out.println(map);
输出结果为:
{A=1, B=2, C=3, D=4}
这次实现了我想要的结果,完美!