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

  

猜你喜欢

转载自www.cnblogs.com/eleven258/p/10057390.html