List集合多次排序

2018-12-03 09:26:16来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

写在前面:

  有时候我们在查询数据展示到前台页面的时候,需要对数据进行排序,特别是按照多个字段进行排序,会很麻烦写的代码也比较多。这个时候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 二次排序,和空指针处理示例

  

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:并发编程之始

下一篇:使用struts框架后的404错误