Comparator是函数式接口,用于自定义排序。通过实现compare方法、使用Lambda表达式或方法引用可灵活排序,支持多级排序与自然/逆序等静态方法组合。

在Java中,Comparator 是一个函数式接口,常用于对集合或数组中的元素进行自定义排序。它比自然排序(Comparable)更灵活,不需要修改类本身就能实现多种排序方式。
可以通过实现 Comparator 接口并重写 compare(T o1, T o2) 方法来自定义排序逻辑。该方法返回一个整数:
import java.util.*;
List<String> words = Arrays.asList("apple", "hi", "banana", "go");
words.sort(new Comparator<String>() {
@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()));
也可以使用方法引用进一步简化:
立即学习“Java免费学习笔记(深入)”;
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<Person> 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<Person> byAgeDesc = Comparator.comparing(Person::getAge).reversed(); people.sort(byAgeDesc);
以上就是在Java中如何使用Comparator自定义排序的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号