Java 开发 - 含有 null 值字段的对象排序(自定义 Comparator、使用 Comparator、使用 Stream API)

准备阶段

  • Student.java
java 复制代码
public class Student {
    private Integer id;
    private String name;

    public Student(Integer id, String name) {
        this.id = id;
        this.name = name;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", name='" + name + '\'' +
                '}';
    }
}

基础排序

  1. 升序排序
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(1003, "王五"));
list.add(new Student(1002, "李四"));

list.sort(Comparator.comparingInt(Student::getId));

System.out.println(list);
复制代码
# 输出结果

[Student{id=1001, name='张三'}, Student{id=1002, name='李四'}, Student{id=1003, name='王五'}]
  1. 降序排序
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(1003, "王五"));
list.add(new Student(1002, "李四"));

list.sort((o1, o2) -> o2.getId() - o1.getId());

System.out.println(list);
复制代码
# 输出结果

[Student{id=1003, name='王五'}, Student{id=1002, name='李四'}, Student{id=1001, name='张三'}]

含有 null 值字段的对象排序

1、自定义 Comparator
  1. 升序排序,含有 null 值字段的对象放在最后面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort((o1, o2) -> {
    Integer id1 = o1.getId();
    Integer id2 = o2.getId();

    if (id1 == null && id2 == null) {
        return 0;
    }
    if (id1 == null) {
        return 1;
    }
    if (id2 == null) {
        return -1;
    }
    return id1 - id2;
});

System.out.println(list);
复制代码
# 输出结果

[Student{id=1001, name='张三'}, Student{id=1002, name='李四'}, Student{id=1005, name='孙七'}, Student{id=null, name='王五'}, Student{id=null, name='赵六'}]
  1. 降序排序,含有 null 值字段的对象放在最后面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort((o1, o2) -> {
    Integer id1 = o1.getId();
    Integer id2 = o2.getId();

    if (id1 == null && id2 == null) {
        return 0;
    }
    if (id1 == null) {
        return 1;
    }
    if (id2 == null) {
        return -1;
    }
    return id2 - id1;
});

System.out.println(list);
复制代码
# 输出结果

[Student{id=1005, name='孙七'}, Student{id=1002, name='李四'}, Student{id=1001, name='张三'}, Student{id=null, name='王五'}, Student{id=null, name='赵六'}]
  1. 升序排序,含有 null 值字段的对象放在最前面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort((o1, o2) -> {
    Integer id1 = o1.getId();
    Integer id2 = o2.getId();

    if (id1 == null && id2 == null) {
        return 0;
    }
    if (id1 == null) {
        return -1;
    }
    if (id2 == null) {
        return 1;
    }
    return id1 - id2;
});

System.out.println(list);
复制代码
# 输出结果

[Student{id=null, name='王五'}, Student{id=null, name='赵六'}, Student{id=1001, name='张三'}, Student{id=1002, name='李四'}, Student{id=1005, name='孙七'}]
  1. 降序排序,含有 null 值字段的对象放在最前面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort((o1, o2) -> {
    Integer id1 = o1.getId();
    Integer id2 = o2.getId();

    if (id1 == null && id2 == null) {
        return 0;
    }
    if (id1 == null) {
        return -1;
    }
    if (id2 == null) {
        return 1;
    }
    return id2 - id1;
});

System.out.println(list);
复制代码
# 输出结果

[Student{id=null, name='王五'}, Student{id=null, name='赵六'}, Student{id=1005, name='孙七'}, Student{id=1002, name='李四'}, Student{id=1001, name='张三'}]
2、使用 Comparator
  1. 升序排序,含有 null 值字段的对象放在最后面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort(
        Comparator.comparing(
                Student::getId,
                Comparator.nullsLast(Comparator.naturalOrder())
        )
);

System.out.println(list);
复制代码
# 输出结果

[Student{id=1001, name='张三'}, Student{id=1002, name='李四'}, Student{id=1005, name='孙七'}, Student{id=null, name='王五'}, Student{id=null, name='赵六'}]
  1. 降序排序,含有 null 值字段的对象放在最后面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort(
        Comparator.comparing(
                Student::getId,
                Comparator.nullsLast(Comparator.reverseOrder())
        )
);

System.out.println(list);
复制代码
# 输出结果

[Student{id=1005, name='孙七'}, Student{id=1002, name='李四'}, Student{id=1001, name='张三'}, Student{id=null, name='王五'}, Student{id=null, name='赵六'}]
  1. 升序排序,含有 null 值字段的对象放在最前面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort(
        Comparator.comparing(
                Student::getId,
                Comparator.nullsFirst(Comparator.naturalOrder())
        )
);

System.out.println(list);
复制代码
# 输出结果

[Student{id=null, name='王五'}, Student{id=null, name='赵六'}, Student{id=1001, name='张三'}, Student{id=1002, name='李四'}, Student{id=1005, name='孙七'}]
  1. 降序排序,含有 null 值字段的对象放在最前面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

list.sort(
        Comparator.comparing(
                Student::getId,
                Comparator.nullsFirst(Comparator.reverseOrder())
        )
);

System.out.println(list);
复制代码
# 输出结果

[Student{id=null, name='王五'}, Student{id=null, name='赵六'}, Student{id=1005, name='孙七'}, Student{id=1002, name='李四'}, Student{id=1001, name='张三'}]
3、使用 Stream API
  1. 升序排序,含有 null 值字段的对象放在最后面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

List<Student> sortedList = list.stream()
        .sorted(Comparator.comparing(
                Student::getId,
                Comparator.nullsLast(Comparator.naturalOrder())
        ))
        .collect(Collectors.toList());

System.out.println(sortedList);
复制代码
# 输出结果

[Student{id=1001, name='张三'}, Student{id=1002, name='李四'}, Student{id=1005, name='孙七'}, Student{id=null, name='王五'}, Student{id=null, name='赵六'}]
  1. 降序排序,含有 null 值字段的对象放在最后面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

List<Student> sortedList = list.stream()
        .sorted(Comparator.comparing(
                Student::getId,
                Comparator.nullsLast(Comparator.reverseOrder())
        ))
        .collect(Collectors.toList());

System.out.println(sortedList);
复制代码
# 输出结果

[Student{id=1005, name='孙七'}, Student{id=1002, name='李四'}, Student{id=1001, name='张三'}, Student{id=null, name='王五'}, Student{id=null, name='赵六'}]
  1. 升序排序,含有 null 值字段的对象放在最前面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

List<Student> sortedList = list.stream()
        .sorted(Comparator.comparing(
                Student::getId,
                Comparator.nullsFirst(Comparator.naturalOrder())
        ))
        .collect(Collectors.toList());

System.out.println(sortedList);
复制代码
# 输出结果

[Student{id=null, name='王五'}, Student{id=null, name='赵六'}, Student{id=1001, name='张三'}, Student{id=1002, name='李四'}, Student{id=1005, name='孙七'}]
  1. 降序排序,含有 null 值字段的对象放在最前面
java 复制代码
List<Student> list = new ArrayList<>();

list.add(new Student(1001, "张三"));
list.add(new Student(null, "王五"));
list.add(new Student(1002, "李四"));
list.add(new Student(null, "赵六"));
list.add(new Student(1005, "孙七"));

List<Student> sortedList = list.stream()
        .sorted(Comparator.comparing(
                Student::getId,
                Comparator.nullsFirst(Comparator.reverseOrder())
        ))
        .collect(Collectors.toList());

System.out.println(sortedList);
复制代码
# 输出结果

[Student{id=null, name='王五'}, Student{id=null, name='赵六'}, Student{id=1005, name='孙七'}, Student{id=1002, name='李四'}, Student{id=1001, name='张三'}]
相关推荐
Nyarlathotep01133 分钟前
SpringBoot Starter的用法以及原理
java·spring boot
wuwen58 分钟前
WebFlux + Lettuce Reactive 中 SkyWalking 链路上下文丢失的修复实践
java
SimonKing29 分钟前
GitHub 10万星的OpenCode,正在悄悄改变我们的工作流
java·后端·程序员
Seven971 小时前
虚拟线程深度解析:轻量并发编程的未来趋势
java
雨中飘荡的记忆11 小时前
ElasticJob分布式调度从入门到实战
java·后端
考虑考虑20 小时前
JDK25模块导入声明
java·后端·java ee
_小马快跑_21 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero1 天前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记1 天前
Spring Boot条件注解详解
java·spring boot
程序员清风2 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试