如何对List排序

对一个字段排序

使用Stream流进行排序

// Comparator.comparing(Xx::getId):这是一个比较器(Comparator),它根据Xx对象的getId方法返回的值来比较Xx对象。
// 不使用Comparator.reverseOrder(),即为从小到大排序。
xxList = xxList.stream().sorted(Comparator.comparing(Xx::getId)).collect(Collectors.toList());
// Comparator.reverseOrder():这个方法将比较器的排序顺序反转,即从大到小排序,而不是默认的从小到大。
xxList = xxList.stream().sorted(Comparator.comparing(Xx::getId, Comparator.reverseOrder())).collect(Collectors.toList());

使用Hutool工具类的方法进行排序

// CollUtil.sortByProperty是从小到大排序,排序后会修改原List,底层调用的是java.util.List#sort方法。CollUtil.reverse能反转排序,也是在原List上直接修改。
CollUtil.reverse(CollUtil.sortByProperty(xxList, "id"));

对多个字段依次排序

使用Stream流进行排序

// Comparator.reverseOrder():这个方法将比较器的排序顺序反转,即从大到小排序,而不是默认的从小到大。
// java.util.Comparator#thenComparing 方法是Java中Comparator接口的一个默认方法,它用于创建一个复合比较器(Comparator),这个复合比较器首先按照一个比较器进行比较,如果比较结果相同,则使用另一个比较器进行比较。
xxList = xxList.stream().sorted(Comparator.comparing(Xx::getId, Comparator.reverseOrder()).thenComparing(Xx::getRemark, Comparator.reverseOrder())).collect(Collectors.toList());
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

付聪1210

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值