stream流分组比较字段大小并取较大值

userList.parallelStream().collect(Collectors.groupingBy(User::getAge, Collectors.collectingAndThen(Collectors.reducing((c1, c2) -> c1.getAge().compareTo(c2.getAge()) > 0 ? c1 : c2), Optional::get)));
如果你想对分组后的结果按照某一个字段进行排序,可以使用Java 8中的Stream API的`Collectors.groupingBy()`和`Collectors.collectingAndThen()`方法来实现。具体步骤如下: 1. 使用`Collectors.groupingBy()`方法对List进行分组,该方法接收一个`Function`参数,用于根据指定的键对元素进行分组。 2. 分组后的结果将会是一个`Map`对象,其中键为分组的键,为包含分组元素的列表。 3. 对Map中的每个键对(即分组后的结果)按照指定的字段进行排序,可以使用`Collectors.collectingAndThen()`方法,该方法接收两个参数:第一个参数是一个收集器,用于对分组元素进行排序;第二个参数是一个函数,用于对排序后的结果进行转换。 下面是一个示例代码,假设我们有一个包含Person对象的List,我们要根据Person对象的年龄分组,并按照Person对象的姓名进行排序: ```java List<Person> persons = Arrays.asList( new Person("John", 20), new Person("Mary", 30), new Person("Bob", 20), new Person("Alice", 30) ); Map<Integer, List<Person>> result = persons.stream() .sorted(Comparator.comparing(Person::getName)) .collect(Collectors.groupingBy(Person::getAge, Collectors.collectingAndThen(Collectors.toList(), Collections::unmodifiableList))); ``` 上面的代码将根据Person对象的年龄进行分组,然后对每个分组结果按照姓名进行排序,并将排序后的结果转换为不可修改的列表。返回一个Map对象,其中键为年龄,为按照姓名排序后的不可修改的Person对象列表。例如,当我们输出结果时: ```java System.out.println(result); ``` 输出结果如下: ```java {20=[Person{name='Bob', age=20}, Person{name='John', age=20}], 30=[Person{name='Alice', age=30}, Person{name='Mary', age=30}]} ``` 可以看到,年龄为20的Person对象被分为一组,并按照姓名排序,年龄为30的Person对象被分为另一组,并按照姓名排序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值