Collections.sort()用于对List排序,支持自然顺序和自定义比较器。元素需实现Comparable接口或传入Comparator实例,如String按字典序、Integer按数值排序,自定义类可通过lambda表达式按字段排序,要求列表可变且非null。
在Java中,Collections.sort() 是一个静态方法,用于对实现了 List 接口的集合进行排序。它依赖于元素的自然顺序或自定义比较规则。以下是具体使用方式。
使用自然排序(元素实现Comparable)
如果列表中的元素类型已经实现了 Comparable 接口(如 String、Integer 等),可以直接调用 Collections.sort() 进行升序排序。
- String 类型按字典顺序排序
- Integer 类型按
数值大小排序
- 自定义类需实现 Comparable 接口并重写 compareTo 方法
示例代码:
Listnames = Arrays.asList("Tom", "Alice", "Bob"); Collections.sort(names); System.out.println(names); // 输出: [Alice, Bob, Tom]
使用自定义比较器(Comparator)
当需要按照特定规则排序,或元素未实现 Comparable 时,可以传入一个 Comparator 实现自定义排序逻辑。
- 通过匿名内部类或 Lambda 表达式定义比较规则
- 可实现降序、多字段排序等复杂逻辑
示例:按字符串长度排序
Listwords = Arrays.asList("java", "go", "python", "c"); Collections.sort(words, (a, b) -> Integer.compare(a.length(), b.length())); System.out.println(words); // 输出: [c, go, java, python]
对自定义对象排序
假设有一个 Person 类,包含 name 和 age 字段,可以通过 Comparator 按年龄排序。
class Person {
String name;
int age;
// 构造方法
Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return name + "(" + age + ")";
}
}
排序示例:
Listpeople = Arrays.asList( new Person("Alice", 30), new Person("Bob", 25), new Person("Charlie", 35) ); Collections.sort(people, (p1, p2) -> p1.age - p2.age); System.out.println(people); // 按年龄升序输出
基本上就这些。只要元素可比较,无论是用自然顺序还是自定义规则,Collections.sort 都能方便地完成列表排序任务。注意列表必须是可变的且支持随机访问,比如 ArrayList,不能是不可变列表或 null。









