Collections.sort()用于对List集合排序,支持自然排序和Comparator自定义排序,排序修改原列表且要求元素实现Comparable或提供比较器,注意空值处理及Java 8后可选用Stream.sorted()。

在Java中,Collections.sort() 是对集合进行排序的常用方法,主要用于对实现了 List 接口的集合进行排序。该方法属于 java.util.Collections 工具类,提供了对集合元素自然排序或自定义排序的支持。
1. 使用 Collections.sort() 进行自然排序
当集合中的元素类型实现了 Comparable 接口时,可以直接调用 Collections.sort(list) 进行升序排序。常见的如 String、Integer 等包装类都已实现 Comparable。
示例代码:
List
names.add("Charlie");
names.add("Alice");
names.add("Bob");
Collections.sort(names); // 按字母顺序排序
System.out.println(names); // 输出:[Alice, Bob, Charlie]
2. 使用 Comparator 实现自定义排序
如果元素未实现 Comparable,或者你想按特定规则排序(如降序、按字段排序),可以传入一个 Comparator 作为第二个参数。
示例:按字符串长度排序
List
Collections.sort(words, (a, b) -> a.length() - b.length());
System.out.println(words); // 输出:[hi, ok, apple, banana]
示例:对自定义对象排序
立即学习“Java免费学习笔记(深入)”;
class Person {
String name;
int age;
Person(String name, int age) { this.name = name; this.age = age; }
}
List
people.add(new Person("Tom", 30));
people.add(new Person("Jane", 25));
// 按年龄排序
Collections.sort(people, (p1, p2) -> p1.age - p2.age);
3. 注意事项与使用建议
使用 Collections.sort() 时需注意以下几点:
- 只能对 List 类型排序,Set、Map 不支持直接排序
- 排序会修改原列表,不会返回新列表
- 元素为 null 时可能抛出 NullPointerException,需提前处理
- 对于大型集合,sort() 使用的是经过优化的归并排序(Timsort),性能良好
- Java 8+ 推荐使用 Stream 的 sorted() 方法以获得更函数式的写法
基本上就这些。Collections.sort() 简单实用,掌握自然排序和 Comparator 自定义排序,就能应对大多数排序需求。不复杂但容易忽略细节,比如可变性与空值处理。实际开发中结合业务场景选择合适的排序方式即可。










