Collections.sort()可用于List的自然排序与自定义排序,支持Comparable对象的默认排序及Comparator指定规则,如按长度、属性排序,并可通过reverseOrder()实现逆序,方法修改原列表且需注意空值与溢出问题。

在Java中,Collections 工具类提供了多种对集合进行操作的静态方法,其中最常用的功能之一就是对List集合进行排序。通过 Collections.sort() 方法,我们可以轻松实现元素的自然排序或自定义排序,提升代码的可读性和开发效率。
使用Collections进行自然排序
当集合中的元素实现了 Comparable 接口时(如String、Integer等),可以直接调用 Collections.sort() 进行自然排序。
例如,对字符串List按字母顺序排序:
Listnames = Arrays.asList("Alice", "Bob", "Charlie"); Collections.sort(names); System.out.println(names); // 输出: [Alice, Bob, Charlie]
对于基本包装类型如Integer、Double等,也默认按升序排列。
立即学习“Java免费学习笔记(深入)”;
使用Comparator实现自定义排序
如果想按照特定规则排序,比如按字符串长度、对象属性等,可以传入一个 Comparator 实现。
示例:按字符串长度排序
Listwords = Arrays.asList("Java", "is", "awesome"); Collections.sort(words, (a, b) -> a.length() - b.length()); System.out.println(words); // 输出: [is, Java, awesome]
也可以使用方法引用来简化代码:
Collections.sort(words, Comparator.comparing(String::length));
对自定义对象进行排序
假设有一个Student类,包含name和age字段,希望按年龄排序:
class Student {
String name;
int age;
// 构造方法、getter等省略
}
使用 Collections.sort() 配合 Comparator:
Liststudents = new ArrayList<>(); students.add(new Student("Alice", 22)); students.add(new Student("Bob", 20)); Collections.sort(students, (s1, s2) -> s1.age - s2.age); // 或使用 Comparator.comparing(Students::getAge)
逆序排序技巧
若需要降序排列,可以使用 Comparator.reverseOrder() 或对比较结果取反。
例如,对数字列表进行降序排序:
Listnumbers = Arrays.asList(3, 1, 4, 1, 5); Collections.sort(numbers, Comparator.reverseOrder()); System.out.println(numbers); // 输出: [5, 4, 3, 1, 1]
对于自定义比较器,也可调用 reversed() 方法反转顺序:
ComparatorbyLength = Comparator.comparing(String::length); Collections.sort(words, byLength.reversed());
基本上就这些。熟练掌握 Collections.sort() 结合 Lambda 和 Comparator 的用法,能让集合排序更加灵活高效。注意该方法只适用于List,且会直接修改原列表内容。不复杂但容易忽略细节,比如空值处理或比较时的溢出问题。










