Collections.sort()可用于排序List集合,支持自然排序、自定义Comparator及逆序排列,要求元素可比较且集合非null。

在Java中,Collections 工具类提供了多种静态方法来操作集合,其中最常用的功能之一就是对集合进行排序。它位于 java.util.Collections 包下,能够对实现了 List 接口的集合进行排序,前提是集合中的元素支持比较操作。
使用 Collections.sort() 对基本类型排序
对于存储基本包装类型(如 Integer、String 等)的 List 集合,可以直接使用 Collections.sort() 方法进行升序排序。
示例代码:
Listnumbers.add(5);
numbers.add(2);
numbers.add(8);
numbers.add(1);
Collections.sort(numbers);
System.out.println(numbers); // 输出 [1, 2, 5, 8]
字符串列表也可以直接排序,按字典顺序排列:
立即学习“Java免费学习笔记(深入)”;
ListCollections.sort(names);
System.out.println(names); // 输出 [Alice, Bob, Tom]
使用自定义比较器排序对象集合
当集合中存储的是自定义对象时,需要通过实现 Comparator 接口来定义排序规则。
例如有一个 Student 类:
class Student {String name;
int age;
Student(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return name + "(" + age + ")";
}
}
按年龄排序:
Liststudents.add(new Student("Alice", 22));
students.add(new Student("Bob", 20));
students.add(new Student("Charlie", 23));
Collections.sort(students, (s1, s2) -> s1.age - s2.age);
System.out.println(students); // 按年龄升序输出
也可以使用方法引用或 Comparator 提供的工具方法:
Collections.sort(students, Comparator.comparingInt(s -> s.age));逆序排序与自然排序
如果想对集合进行降序排列,可以使用 Collections.reverseOrder() 获取一个逆序比较器。
示例:对整数列表降序排序
Collections.sort(numbers, Collections.reverseOrder());System.out.println(numbers); // 输出 [8, 5, 2, 1]
对自定义对象按名字降序:
Collections.sort(students, Comparator.comparing(s -> s.name).reversed());基本上就这些。只要集合是可比较的,或者提供了比较逻辑,Collections.sort() 就能完成排序任务。注意该方法只适用于 List,不适用于 Set 或 Map。排序前确保集合不为 null,且元素支持比较,否则可能抛出异常。










