map.merge(key,value,(v1,v2) -> v1+v2);
merge方法可以这么理解。如上式,
1.key不存在等于是map.put(key, value),后面的处理失效。
2..key存在,value就会变成你处理后的value值。
这是mager的源码决定的。
例子
public static void main(String[] args) {
Map<String, Integer> map1 = new HashMap<>();
map1.put("a",1);
map1.put("b",2);
map1.put("c",3);
System.out.println(map1);
//key不存在等于是map1.put(key, value),后面的处理失效。
map1.merge("d",4,(v1,v2)->v2+100);
//如果存在就会变成你处理后的value值
map1.merge("a",100,(v1,v2)->v1+v2);
System.out.println(map1);
map1.merge("c",3,Integer::sum);
map1.merge("a",4,(v1,v2)->null);
System.out.println(map1);
}
结果: {a=1, b=2, c=3} {a=101, b=2, c=3, d=4} {b=2, c=6, d=4}
可以看出key为"d"时,不管你后面如何处理,都只会把value值put进去。
key为"a"时,put进去后面处理后的值。
如果你处理后的值为null,这个key会被移除。