collector list 多个分组_Java 流分组

1f954b95bf81441377b5b328708add25.png

Collectors类中的groupingBy()方法返回一个收集器,用于在将数据收集到Map之前对数据进行分组。 它类似于SQL中的“group by”子句。

groupingBy()方法是重载的,它有三个版本:

groupingBy(Function super T,? extends K> classifier)

groupingBy(Function super T,? extends K> classifier, Collector super T,A,D> downstream)

groupingBy(Function super T,? extends K> classifier, Supplier mapFactory, Collector super T,A,D> downstream)

在前两个版本中,收集器负责为您创建Map对象。第三个版本允许我们指定一个用作工厂的Supplier来获取Map对象。

classifier 函数生成地图中的键。 collector 对与每个键相关联的值执行简化操作。

以下代码显示了如何按性别和计算每个组中的人数。

Collectors类的counting()方法返回要计数的Collector流中的元素数。

import java.time.LocalDate;import java.time.Month;import java.util.Arrays;import java.util.List;import java.util.Map;import java.util.stream.Collectors;public class Main { public static void main(String[] args) { Map countByGender = Employee.persons() .stream() .collect(Collectors.groupingBy(Employee::getGender, Collectors.counting()));  System.out.println(countByGender); }}class Employee { public static enum Gender { MALE, FEMALE } private long id; private String name; private Gender gender; private LocalDate dob; private double income; public Employee(long id, String name, Gender gender, LocalDate dob, double income) { this.id = id; this.name = name; this.gender = gender; this.dob = dob; this.income = income; } public Gender getGender() { return gender; } public static List persons() { Employee p1 = new Employee(1, "Jake
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值