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

在Java中,Comparator 是一个函数式接口,常用于对集合或数组中的元素进行自定义排序。它比自然排序(Comparable)更灵活,不需要修改类本身就能实现多种排序方式。
1. 实现Comparator接口
可以通过实现 Comparator 接口并重写 compare(T o1, T o2) 方法来自定义排序逻辑。该方法返回一个整数:
- 负数:o1 小于 o2
- 0:o1 等于 o2
- 正数:o1 大于 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]
2. 使用Lambda表达式简化
由于 Comparator 是函数式接口,可以用 Lambda 表达式简化代码。
同样的字符串长度排序:words.sort((s1, s2) -> Integer.compare(s1.length(), s2.length()));
也可以使用方法引用进一步简化:
自定义设置的程度更高可以满足大部分中小型企业的建站需求,同时修正了上一版中发现的BUG,优化了核心的代码占用的服务器资源更少,执行速度比上一版更快 主要的特色功能如下: 1)特色的菜单设置功能,菜单设置分为顶部菜单和底部菜单,每一项都可以进行更名、选择是否隐 藏,排序等。 2)增加企业基本信息设置功能,输入的企业信息可以在网页底部的醒目位置看到。 3)增加了在线编辑功能,输入产品信息,企业介绍等栏
立即学习“Java免费学习笔记(深入)”;
words.sort(Comparator.comparing(String::length));
3. 组合多个排序条件
可以链式调用 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()));
4. 常用静态和默认方法
Comparator 提供了许多便捷的静态方法:
- Comparator.naturalOrder():自然顺序
- Comparator.reverseOrder():逆序
- Comparator.comparing(Function):根据提取的键排序
- comparator.reversed():反转排序顺序
Comparator基本上就这些。掌握 Comparator 能让你灵活控制排序逻辑,尤其在处理复杂对象时非常实用。byAgeDesc = Comparator.comparing(Person::getAge).reversed(); people.sort(byAgeDesc);









