• 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 二次排序,和空指针处理示例

      

  • 相关阅读:
    基础知识
    贪心-合并区间、交集、无重叠区间、俄罗斯套娃信封
    递归实现煎饼排序
    递归实现基本计算器+-*/()
    滑动窗口---最小覆盖子串、字母异位词、
    二分查找
    N皇后
    二叉搜索树-合法性、增、删、查
    循环
    二分法
  • 原文地址:https://www.cnblogs.com/eleven258/p/10057390.html
Copyright © 2020-2023  润新知