Collectors.groupingBy可用于分组统计,如按部门统计员工数量:Map<String, Long> countByDept = employees.stream().collect(Collectors.groupingBy(Employee::getDepartment, Collectors.counting()));

在Java中,可以使用 Collectors.groupingBy 对集合中的数据按指定条件进行分组,并统计每组的数量或汇总信息。这个方法通常与 Stream API 配合使用,适合处理 List、Set 等集合类型的数据。
Collectors.groupingBy 有三种常见重载形式:
假设有一个员工类:
class Employee {现在要按部门统计员工人数:
立即学习“Java免费学习笔记(深入)”;
Map结果是一个 Map,key 是部门名,value 是该部门员工数量。
如果想先按部门分组,再在每个部门内按姓名长度分组:
Map这会生成一个两级 Map:外层 key 是部门,内层 key 是名字长度。
除了统计数量,还可以求和、取平均值等:
Collectors.counting()
Collectors.summingDouble(Employee::getSalary)
Collectors.toList()
Collectors.toSet()
例如,统计每个部门的平均工资:
Map基本上就这些。灵活组合 groupingBy 和下游收集器,能应对大多数分组统计场景。关键是理解函数式接口如何提取分组依据,以及如何嵌套使用收集器。
以上就是在Java中如何使用Collectors.groupingBy统计分组数据的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号