List集合多次排序

写在前面:

  有时候我们在查询数据展示到前台页面的时候,需要对数据进行排序,特别是按照多个字段进行排序,会很麻烦写的代码也比较多。这个时候java8的特性可以让我们很方便的对数据进行排序。

 

  话不多说,直接上代码。

public class Test {
    public static void main(String[] args) {
        List<DoubleSort> list = new ArrayList<DoubleSort>();
        list.add(new DoubleSort(0, "1",12));
        list.add(new DoubleSort(3, "2",15));
        list.add(new DoubleSort(2, "22",12));
        list.add(new DoubleSort(3, "11",17));
        list.add(new DoubleSort(3, "222",13));
        list.add(new DoubleSort(3, null,10));
// 简单排序 按照id升序排序
        list.sort(Comparator.comparing(DoubleSort::getId));
        list.forEach(e -> System.out.println(e.getId() + "," + e.getName()+","+e.getAge()));
        System.out.println("----");
// 二次排序 按照id,age升序排序(先按照id排序,id相同的按照age排序)
        list.sort(Comparator.comparing(DoubleSort::getId).thenComparing(DoubleSort::getAge));
        list.forEach(e -> System.out.println(e.getId() + "," + e.getName()+","+e.getAge()));
        System.out.println("----");
// 多次排序 按照id,name,age升序排序(先按照id排序,id相同的按照name升序排序(当name有null值,排序最前面),然后name相同的按照age升序排序)
        list.sort(Comparator.comparing(DoubleSort::getId).thenComparing(DoubleSort::getName, Comparator.nullsFirst(Comparator.naturalOrder())).thenComparing(DoubleSort::getAge));
        list.forEach(e -> System.out.println(e.getId() + "," + e.getName()));
    }
}

  上面代码的最后一个排序中包含有当指定属性为null时的处理方式,我们可以将为null的排在最前面,直接调用对应的方法即可,非常方便,省去了不少的代码呢!

 

 

  参考资料:

  https://blog.csdn.net/york_2016/article/details/80169467------java 8 二次排序,和空指针处理示例

  

 

转载于:https://www.cnblogs.com/eleven258/p/10057390.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值