Java8 lambda如何对Map的集合进行分组并求和

2024-01-03 18:42:18

Java8 lambda如何对Map的集合按照Key进行分组并将Value求和?由于业务中遇到了这样的场景,想通过简单的方式进行求和统计,于是借助lambda表达式进行实现,下边是示例的代码:

import java.util.*;
import java.util.stream.Collectors;

public class MapMergeExample {
    public static void main(String[] args) {
        List<Map<String, Long>> mapList = new ArrayList<>();

        Map<String, Long> map1 = new HashMap<>();
        map1.put("key1", 10L);
        map1.put("key2", 20L);
        mapList.add(map1);

        Map<String, Long> map2 = new HashMap<>();
        map2.put("key2", 30L);
        map2.put("key3", 40L);
        mapList.add(map2);

        Map<String, Long> result = mergeMaps(mapList);
        System.out.println(result);
    }

    public static Map<String, Long> mergeMaps(List<Map<String, Long>> mapList) {
        return mapList.stream()
                .flatMap(map -> map.entrySet().stream())
                .collect(Collectors.groupingBy(
                        Map.Entry::getKey,
                        Collectors.summingLong(Map.Entry::getValue)
                ));
    }
}

首先将所有Map对象的键值对使用flatMap展开成一个流,然后使用Collectors.groupingBy对相同的键进行分组,并使用Collectors.summingLong计算相同键的值之和。

文章来源:https://blog.csdn.net/iamlihongwei/article/details/135369818
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。