Comparator是Java中用于自定义对象排序规则的函数式接口,支持多条件、临时及无需修改类源码的灵活排序,常用comparing、thenComparing和reversed等静态方法。

在Java中,Comparators 是一个函数式接口,位于 java.util.Comparator 包下,用于定义对象之间的比较规则,尤其适用于排序操作。
Comparator 的作用
它允许你自定义两个对象的排序方式,而不依赖于对象本身的 compareTo 方法(即不依赖 Comparable 接口)。这在以下场景非常有用:
- 你想对某个类的对象按多种不同方式排序(比如按姓名、年龄、分数等)
- 你无法修改目标类的源码,因此不能实现 Comparable
- 你想临时改变排序逻辑,而不是固定在类中
基本用法示例
假设有一个 Person 类:
class Person {
String name;
int age;
Person(String name, int age) {
this.name = name;
this.age = age;
}
}
你可以创建一个 Comparator 按年龄排序:
立即学习“Java免费学习笔记(深入)”;
ComparatorbyAge = (p1, p2) -> Integer.compare(p1.age, p2.age);
然后在集合中使用:
Listpeople = new ArrayList<>(); people.add(new Person("Alice", 30)); people.add(new Person("Bob", 25)); people.sort(byAge); // 按年龄升序排列
常用静态方法(Java 8+)
Comparator 提供了许多便捷的静态方法,简化开发:
- Comparator.comparing(Function):根据提取的值排序
- thenComparing():多级排序
- reversed():反转顺序
例如:
Comparator基本上就这些。Comparator 灵活强大,是 Java 集合排序的核心工具之一。cmp = Comparator .comparing((Person p) -> p.name) .thenComparingInt(p -> p.age); people.sort(cmp);











