首页 > 基础资料 博客日记
Java中 List 集合,通过 Stream 流进行排序总结
2024-09-08 14:00:07基础资料围观89次
这篇文章介绍了Java中 List 集合,通过 Stream 流进行排序总结,分享给大家做个参考,收藏Java资料网收获更多编程知识
一、数据准备
public class OrderTest {
private String channelCode;
private BigDecimal rate;
// 省略 getter、setter、toString()、constructor
}
List<OrderTest> orderTestList = new ArrayList<>();
OrderTest z09 = new OrderTest("Z09", new BigDecimal("7.6677"));
OrderTest B2C = new OrderTest("B2C", new BigDecimal("5.6666"));
OrderTest Z04 = new OrderTest("Z04", new BigDecimal("4.3137"));
OrderTest ALL = new OrderTest("ALL", new BigDecimal("4.3137"));
OrderTest ALL1 = new OrderTest("ALL", new BigDecimal("4.5137"));
// 演示多字段排序使用
OrderTest z091 = new OrderTest("Z09", new BigDecimal("7.6671"));
// 演示给 null 值排序用
OrderTest z092 = new OrderTest("Z09", null);
OrderTest B2C1 = new OrderTest("B2C", new BigDecimal("5.6666"));
OrderTest Z041 = new OrderTest("Z04", null);
orderTestList.add(z09);
orderTestList.add(z091);
orderTestList.add(B2C);
orderTestList.add(Z04);
orderTestList.add(ALL);
orderTestList.add(ALL1);
二、单字段排序
2.1、升序
list.stram().sorted(Comparator.Comparing(YourClass::Class's Field)
System.out.println("----------------------------------------------");
System.out.println("只按照 channelCode 升序排序:");
List<OrderTest> channelAsc =
orderTestList.stream()
.sorted(Comparator.comparing(OrderTest::getChannelCode))
.collect(Collectors.toList());
channelAsc.forEach(System.out::println);
结果:
2.2、降序
list.stram().sorted(Comparator.Comparing(YourClass::Class's Field, Comparator.reverseOrder())
System.out.println("----------------------------------------------");
System.out.println("只按照 channelCode 降序排序:");
List<OrderTest> channelDesc =
orderTestList.stream()
.sorted(Comparator.comparing(OrderTest::getChannelCode, Comparator.reverseOrder()))
.collect(Collectors.toList());
channelDesc.forEach(System.out::println);
结果:
二、多字段排序
利用的是 thenComparing():
升序 thenComparing(YourClass::Class's Field),
降序 thenComparing(YourClass::Class's Field, Comparator.reverseOrder())。
注意: 使用 thenComparing(YourClass::Class's Field).reversed() 的时候要注意排序要求,
如果先按照 A 字段升序 B 字段升序的话,使用 reversed() 之后的结果是对 A 降序 B 降序。
System.out.println("----------------------------------------------");
System.out.println("先按照 channelCode 升序,再按照 rate 升序排序:");
List<OrderTest> channelCodeAscRateAscList =
orderTestList.stream()
.sorted(Comparator.comparing(OrderTest::getChannelCode)
.thenComparing(OrderTest::getRate))
.collect(Collectors.toList());
channelCodeAscRateAscList.forEach(System.out::println);
结果
先按照 channelCode 将序,再按照 rate 升序将序,使用 reversed():
System.out.println("----------------------------------------------");
System.out.println("先按照 channelCode 将序,再按照 rate 将序排序,使用 reversed():");
List<OrderTest> channelCodeAscRateAscWithReversedList =
orderTestList.stream()
.sorted(Comparator.comparing(OrderTest::getChannelCode)
.thenComparing(OrderTest::getRate).reversed())
.collect(Collectors.toList());
channelCodeAscRateAscWithReversedList.forEach(System.out::println);
结果
三、对 null 值处理
Comparator.nullsFirst(Comparator.reverseOrder()) -- null排在前面,reverseOrder是倒序,升序用naturalOrder
Comparator.nullsLast(Comparator.reverseOrder()) -- null排在后面,reverseOrder是倒序,升序用naturalOrder
orderTestList.add(new OrderTest(("Z09")));
orderTestList.add(new OrderTest(("B2C")));
orderTestList.add(new OrderTest(("Z04")));
System.out.println("----------------------------------------------");
System.out.println("先按照 channelCode 升序,再按照 rate 降序并且 null 值放前面排序:");
List<OrderTest> channelCodeAscRateDescNullFirstList = orderTestList.stream()
.sorted(Comparator.comparing(OrderTest::getChannelCode)
.thenComparing(OrderTest::getRate, Comparator.nullsFirst(Comparator.reverseOrder())))
.collect(Collectors.toList());
channelCodeAscRateDescNullFirstList.forEach(System.out::println);
结果
四、对排序字段个数不固定的情况,如何排序
需求:排序字段个数不确定,如何实现动态排序?
伪代码示例:
Comparator<SurgUnArrangeResponse> comparing = null;
for (int i = 0; i < dictItemList.size(); i++) {
String cd = dictItemList.get(i).getCd();
if (i == 0) {
// 首次排序
comparing = getComparingByDictCd(cd, null);
} else {
// 第二次排序及以上
comparing = getComparingByDictCd(cd, comparing);
}
}
// comparing 比较器,保存了排序的规则,responseList 是被排序的集合
responseList = responseList.stream().sorted(comparing)
.collect(Collectors.toList());
// getComparingByDictCd 方法
private Comparator<SurgUnArrangeResponse> getComparingByDictCd(String dictCd,
Comparator<SurgUnArrangeResponse> result = null;
switch (dictCd) {
case "age":
result = comparing == null ? Comparator.comparing(SurgUnArrangeResponse::getAge, Comparator.nullsLast(Comparator.reverseOrder())) :
comparing.thenComparing(SurgUnArrangeResponse::getAge, Comparator.nullsLast(Comparator.reverseOrder()));
break;
....
}
return result;
}
文章来源:https://blog.csdn.net/KevinChen2019/article/details/137017915
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
上一篇:Java中的IO流-最全最基础的IO流概述和简介
下一篇:Jvm 浅析