如何轻松地将两个hashMap <string,integer>?

时间:2015-11-10 21:38:06

标签: java hashmap hashtable

我有两个HashMap<String,Integer>

我怎样才能轻松总结它们?

意味着对于字符串“a”,键将是(Map1的值+ Map2的值)的总和?

我可以迭代Map2的每个项目并手动添加到Map1。

但是认为可能有一种更简单的方法?

我更喜欢将整数汇总到其中一张地图中。没有创建新的

3 个答案:

答案 0 :(得分:12)

由于Java 8 Map包含merge方法,需要

  • key,
  • 新值,
  • 以及用于决定在地图中放置什么值的函数(如果它已包含我们的密钥)(将根据旧值和新值做出决定)。

所以你可以简单地使用:

map2.forEach((k, v) -> map1.merge(k, v, Integer::sum));

现在,您的map1将包含来自map2的所有值,如果相同的键,旧值将添加到新值,结果将存储在地图中。

样本:

Map<String, Integer> m1 = new HashMap<>();
m1.put("a", 1);
m1.put("b", 2);
Map<String, Integer> m2 = new HashMap<>();
m2.put("a", 3);
m2.put("c", 10);

System.out.println(m1);
System.out.println(m2);

//iterate over second map and merge its elements into map 1 using 
//same key and sum of values
m2.forEach((k, v) -> m1.merge(k, v, Integer::sum));

System.out.println("===========");
System.out.println(m1);

输出:

{a=1, b=2}
{a=3, c=10}
===========
{a=4, b=2, c=10}

答案 1 :(得分:1)

不幸的是,没有简单的方法。您需要手动迭代它们。

import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;

public class HashMapSum {

    public static void main(String[] args) {
        Map<String, Integer> map1 = new HashMap<String, Integer>();
        map1.put("a", 1);
        map1.put("b", 2);
        map1.put("c", 3);

        Map<String, Integer> map2 = new HashMap<String, Integer>();
        map2.put("a", 4);
        map2.put("b", 5);
        map2.put("d", 6);

        Set<String> keySet = new HashSet<String>();
        keySet.addAll(map1.keySet());
        keySet.addAll(map2.keySet());

        Map<String, Integer> map3 = new HashMap<String, Integer>();
        Integer val1, val2;
        for (String key : keySet) {
            val1 = map1.get(key);
            val1 = (val1 == null ? 0 : val1);
            val2 = map2.get(key);
            val2 = (val2 == null ? 0 : val2);
            map3.put(key, val1 + val2);
        }

        System.out.println(map3.toString());
    }
}

答案 2 :(得分:1)

如果你喜欢Java 8:

Map<String, Integer> sum(Map<String, Integer>... maps) {
    return Stream.of(maps)    // Stream<Map<..>>
            .map(Map::entrySet)  // Stream<Set<Map.Entry<..>>
            .flatMap(Collection::stream) // Stream<Map.Entry<..>>
            .collect(Collectors.toMap(Map.Entry::getKey,
                                      Map.Entry::getValue,
                                      Integer::sum));
}

可以总结任意数量的地图。它将前面几行中的映射数组转换为Stream<Map.Entry<String, Integer>,然后将所有条目收集到一个新的Map中,同时在重复值的情况下提供“合并函数”。

或类似

的内容
void addToA(HashMap<String, Integer> a, HashMap<String, Integer> b) {
    for (Entry<String, Integer> entry : b.entrySet()) {
        Integer old = a.get(entry.getKey());
        Integer val = entry.getValue();
        a.put(entry.getKey(), old != null ? old + val : val);
    }
}