生产环境中需要用到的排序场景无非以下几种:
- 按某个字段升降序(逆序)排列
- 按多个字段升降序排序(包含,字段1升序,字段2降序排列)
- 对null值友好排列
1.实现
package com.xxx.sort;
import com.google.common.collect.Lists;
import lombok.Builder;
import lombok.Data;
import java.util.*;
/**
* @author wangzhen
* @date 2019-12-20
*/
public class SortDemo {
@Data @Builder
private static class Student {
private String name;
private int age;
private int grade;
}
private static List<Student> init(int n) {
ArrayList<Student> list = Lists.newArrayList();
for (int i = 0; i < n; i++) {
Student student = Student.builder().age(i + 20).name("test"+i).grade(new Random().nextInt(100)).build();
list.add(student);
}
return list;
}
public static void printList(List<Student> list) {
list.forEach(System.out::println);
System.out.println("------------------------------------------------");
}
public static void main(String[] args) {
// 初始化list
List<Student> list = init(5);
// 1.单字段排序.Comparator 默认升序
list.sort(Comparator.comparing(Student::getGrade));
printList(list);
// 逆序
list.sort(Comparator.comparing(Student::getGrade).reversed());
printList(list);
// 2. 多字段排序,优先判断前面,一样的再按后面的规则排序
list.add(Student.builder().age(4).name("a").build());
list.add(Student.builder().age(2).name("a").build());
list.sort(Comparator.comparing(Student::getGrade).thenComparing(Student::getAge));
printList(list);
// 3. 对null值友好排序
list.add(Student.builder().age(0).name("for test null and will be sorted first").build());
list.sort(Comparator.nullsFirst(Comparator.comparing(Student::getGrade)));
// nullsLast
printList(list);
}
}
2.小结
// 1.单字段排序.Comparator 默认升序
list.sort(Comparator.comparing(Student::getGrade));
// 逆序 reversed
list.sort(Comparator.comparing(Student::getGrade).reversed());
// 2. 多字段排序,优先判断前面,一样的再按后面的规则排序 thenComparing
list.sort(Comparator.comparing(Student::getGrade).thenComparing(Student::getAge));
// 3. 对null值友好排序 nullsFirst、nullsLast
list.sort(Comparator.nullsFirst(Comparator.comparing(Student::getGrade)));