stream流排序

本文介绍了如何使用Java8 Stream流对List进行倒序排列,特别是讲解了两种不同的多字段排序方式:Comparator.comparing().reversed()和Comparator.comparing().reverseOrder()的区别,强调了第二种方式的直观易懂。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

List 倒序排列

List<Double> salesData = new ArrayList<>();
 
Collections.reverse(salesData);

	// 降序 反序
Collections.reverse(value.stream().sorted(Comparator.comparing(x -> x.getPath().length(), Comparator.reverseOrder())).collect(Collectors.toList()));
	// 升序
value.stream().sorted(Comparator.comparing(x -> x.getPath().length()));
	

java8 stream多字段排序

List<> rankList = new ArrayList<>(); 代表某个集合
 
//返回 对象集合以类属性一升序排序
 
rankList.stream().sorted(Comparator.comparing(::属性一));
 
//返回 对象集合以类属性一降序排序 注意两种写法
 
rankList.stream().sorted(Comparator.comparing(::属性一).reversed()); //先以属性一升序,然后对结果集进行属性一降序
 
rankList.stream().sorted(Comparator.comparing(::属性一, Comparator.reverseOrder())); //以属性一降序
 
//返回 对象集合以类属性一升序 属性二升序
 
rankList.stream().sorted(Comparator.comparing(::属性一).thenComparing(::属性二));
 
//返回 对象集合以类属性一降序 属性二升序 注意两种写法
 
rankList.stream().sorted(Comparator.comparing(::属性一).reversed().thenComparing(::属性二));//先以属性一升序,升序结果进行属性一降序,再进行属性二升序
 
rankList.stream().sorted(Comparator.comparing(::属性一,Comparator.reverseOrder()).thenComparing(::属性二));//先以属性一降序,再进行属性二升序
 
//返回 对象集合以类属性一降序 属性二降序 注意两种写法
 
rankList.stream().sorted(Comparator.comparing(::属性一).reversed().thenComparing(::属性二,Comparator.reverseOrder()));//先以属性一升序,升序结果进行属性一降序,再进行属性二降序
 
rankList.stream().sorted(Comparator.comparing(::属性一,Comparator.reverseOrder()).thenComparing(::属性二,Comparator.reverseOrder()));//先以属性一降序,再进行属性二降序
 
//返回 对象集合以类属性一升序 属性二降序 注意两种写法
 
rankList.stream().sorted(Comparator.comparing(::属性一).reversed().thenComparing(::属性二).reversed());//先以属性一升序,升序结果进行属性一降序,再进行属性二升序,结果进行属性一降序属性二降序
 
rankList.stream().sorted(Comparator.comparing(::属性一).thenComparing(::属性二,Comparator.reverseOrder()));//先以属性一升序,再进行属性二降序

注意两种写法

1、 Comparator.comparing(类::属性一).reversed();

2、 Comparator.comparing(类::属性一,Comparator.reverseOrder());

两种排序是完全不一样的,一定要区分开来:方式1是得到排序结果后再排序,方式2是直接进行排序!!!方式2更好理解。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值