Comparator是函数式接口,用于自定义排序。通过实现compare方法、使用Lambda表达式或方法引用可灵活排序,支持多级排序与自然/逆序等静态方法组合。
在Java中,Comparator 是一个函数式接口,常用于对集合或数组中的元素进行自定义排序。它比自然排序(Comparable)更灵活,不需要修改类本身就能实现多种排序方式。
可以通过实现 Comparator 接口并重写 compare(T o1, T o2) 方法来自定义排序逻辑。该方法返回一个整数:
import java.util.*; Listwords = Arrays.asList("apple", "hi", "banana", "go"); words.sort(new Comparator () { @Override public int compare(String s1, String s2) { return Integer.compare(s1.length(), s2.length()); } }); System.out.println(words); // 输出: [hi, go, apple, banana]
由于 Comparator 是函数式接口,可以用 Lambda 表达式简化代码。
同样的字符串长度排序:words.sort((s1, s2) -> Integer.compare(s1.length(), s2.length()));
也可以使用方法引用进一步简化:
words.sort(Comparator.comparing(String::length));
可以链式调用 Comparator 的默认方法实现多级排序。
例如,先按姓名升序,再按年龄降序:class Person {
String name;
int age;
// 构造方法
public Person(String name, int age) {
this.name = name;
this.age = age;
}
// getter 方法(省略)
}
List people = Arrays.asList(
new Person("Alice", 30),
new Person("Bob", 25),
new Person("Alice", 20)
);
people.sort(Comparator.comparing(Person::getName)
.thenComparing(Person::getAge, Comparator.reverseOrder()));
Comparator 提供了许多便捷的静态方法:
Comparator基本上就这些。掌握 Comparator 能让你灵活控制排序逻辑,尤其在处理复杂对象时非常实用。byAgeDesc = Comparator.comparing(Person::getAge) .reversed(); people.sort(byAgeDesc);