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免费学习笔记(深入)”;
自从百度屏蔽淘宝客网站、淘宝抛弃淘宝客之后,个人站长集体陷入了恐慌之中。此时,什么值得买网的异军突起引起了广大个人站长的极大关注。做一个什么值得买一样的导购网站成了众多个人站长的一致心愿! TP-COUPON 导购系统 即是让个人站长实现此心愿的绝佳选择! 欢迎个人站长选用。V1.1版 更新记录:1.修正请求时查询淘宝店铺错误的bug2.删除一些无用的代码
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);










