Collections.sort()用于对List集合排序,支持自然排序和自定义Comparator排序,基于稳定算法实现。

在Java中,Collections.sort() 是对集合进行排序的常用方法,适用于实现了 List 接口的集合类型。它基于稳定的排序算法(归并排序或优化的快速排序),能够高效地对元素进行自然排序或自定义排序。
使用自然排序(Natural Ordering)
当集合中的元素类型实现了 Comparable 接口时,可以直接调用 Collections.sort() 进行自然排序。
- String、Integer、Double 等包装类都默认实现了 Comparable。
- 排序时按升序排列:数字从小到大,字符串按字典顺序。
示例代码:
Listnames = new ArrayList<>(); names.add("Alice"); names.add("Charlie"); names.add("Bob"); Collections.sort(names); System.out.println(names); // 输出: [Alice, Bob, Charlie]
使用比较器排序(Custom Comparator)
若需要自定义排序规则,可传入一个 Comparator 实现作为第二个参数。
立即学习“Java免费学习笔记(深入)”;
- 适用于未实现 Comparable 的类,或需要不同排序逻辑的场景。
- 可以按对象的某个字段排序,如按年龄、姓名、时间等。
示例:按字符串长度排序
Android文档-开发者指南-第一部分:入门-中英文对照版 Android提供了丰富的应用程序框架,它允许您在Java语言环境中构建移动设备的创新应用程序和游戏。在左侧导航中列出的文档提供了有关如何使用Android的各种API来构建应用程序的详细信息。第一部分:Introduction(入门) 0、Introduction to Android(引进到Android) 1、Application Fundamentals(应用程序基础) 2、Device Compatibility(设备兼容性) 3、
Listwords = Arrays.asList("apple", "hi", "banana", "ok"); Collections.sort(words, (a, b) -> a.length() - b.length()); System.out.println(words); // 输出: [hi, ok, apple, banana]
对自定义对象排序
假设有一个 Person 类,包含 name 和 age 字段,可以通过 Comparator 按年龄排序。
class Person {
String name;
int age;
Person(String name, int age) {
this.name = name;
this.age = age;
}
}
List people = new ArrayList<>();
people.add(new Person("Tom", 30));
people.add(new Person("Jane", 25));
people.add(new Person("Lee", 35));
Collections.sort(people, (p1, p2) -> p1.age - p2.age);
// 遍历输出
for (Person p : people) {
System.out.println(p.name + ": " + p.age);
}
// 输出: Jane(25), Tom(30), Lee(35)
注意事项与建议
使用 Collections.sort() 时需注意以下几点:
- 只能对 List 类型排序,Set 和 Map 不支持直接排序。
- 原集合会被修改(就地排序),如需保留原顺序,应先复制。
- 元素为 null 时可能抛出 NullPointerException,建议提前处理空值。
- Java 8+ 更推荐使用 List 的 sort() 方法或 Stream API,更灵活简洁。
例如使用 Stream 排序:
Listsorted = words.stream() .sorted((a, b) -> a.length() - b.length()) .collect(Collectors.toList());
基本上就这些。Collections.sort 虽然传统但依然实用,掌握它有助于理解 Java 集合排序机制。实际开发中可根据需求选择更现代的写法。不复杂但容易忽略细节。









