Collections.sort()可对List元素排序,支持自然排序与Comparator自定义规则;基本类型和实现Comparable的类可直接排序,自定义对象推荐使用Comparator实现灵活排序。

在Java中,Collections 工具类提供了多种操作集合的静态方法,其中排序是最常用的功能之一。通过 Collections.sort() 方法,我们可以轻松对列表(List)中的元素进行排序,无论是基本类型的包装类还是自定义对象,都能高效处理。
使用 Collections.sort() 对基本类型排序
对于存储了字符串或数字包装类(如 Integer、double)的 List,可以直接使用 Collections.sort() 进行升序排序。
示例:
List
该方法默认按元素的自然顺序(Natural Order)排序,要求元素实现 Comparable 接口。String 和常见包装类都已实现此接口。
使用 Comparator 自定义排序规则
当需要自定义排序逻辑时(如降序、按字段排序等),可以传入一个 Comparator 实现作为参数。
立即学习“Java免费学习笔记(深入)”;
常见用法包括:
- 按字符串长度排序:
Collections.sort(list, (a, b) -> a.Length() - b.length()); - 数字降序排列:
Collections.sort(numbers, Collections.reverSEOrder()); - 对自定义对象排序,例如按 Person 的年龄升序:
Collections.sort(people, (p1, p2) -> p1.getAge() - p2.getAge());
对自定义对象进行排序
若要对自定义类的对象列表排序,有两种方式:
- 实现 Comparable 接口:在类中重写
compareTo()方法,定义默认排序规则。
例如:public class Person implements Comparable<Person> { … } - 使用 Comparator:不修改类本身,在排序时传入外部比较器,更灵活,适合多种排序需求。
推荐优先使用 Comparator,便于维护和扩展。
基本上就这些。掌握 Collections.sort() 配合 Comparable 与 Comparator 的使用,就能应对大多数排序场景。注意:传入的列表必须是可修改的,并且所有元素之间应能相互比较,否则可能抛出异常。