Collections.sort()用于排序,要求元素实现Comparable或传入Comparator;2. Collections.reverse()反转列表顺序;3. 降序可通过先sort后reverse或使用Comparator.reverseOrder()实现。

在Java中,Collections 工具类提供了多种操作集合的静态方法,其中最常用的就是对List进行排序和反转。这些方法位于 java.util.Collections 类中,使用时无需创建实例,直接通过类名调用即可。
排序集合:Collections.sort()
Collections 提供了 sort() 方法用于对 List 集合中的元素进行排序。该方法要求集合中的元素必须实现 Comparable 接口,或者传入一个 Comparator 比较器。
基本用法如下:
- 对字符串List按字母顺序排序:
words.add("banana");
words.add("apple");
words.add("cherry");
Collections.sort(words); // 默认升序
System.out.println(words); // 输出 [apple, banana, cherry]
- 对自定义对象排序,比如按年龄排序的Person类:
String name;
int age;
Person(String name, int age) { this.name = name; this.age = age; }
}
List
new Person("Tom", 25),
new Person("Jane", 20),
new Person("Jack", 30)
);
// 使用 Comparator 按年龄排序
Collections.sort(people, (p1, p2) -> Integer.compare(p1.age, p2.age));
反转集合:Collections.reverse()
reverse() 方法用于将List中元素的顺序完全颠倒。它不会进行排序,只是把原有顺序反过来。
立即学习“Java免费学习笔记(深入)”;
示例:
Listnumbers.add(1);
numbers.add(2);
numbers.add(3);
System.out.println("反转前:" + numbers); // [1, 2, 3]
Collections.reverse(numbers);
System.out.println("反转后:" + numbers); // [3, 2, 1]
注意:reverse() 是直接修改原列表,不返回新列表。
结合排序与反转实现降序
如果想让List按降序排列,可以先排序再反转,或者直接使用Comparator反向比较。
- 方式一:排序后反转(简单直观)
Collections.sort(list); // 升序 [1, 2, 5, 8]
Collections.reverse(list); // 反转 [8, 5, 2, 1]
- 方式二:使用 Comparator.reverseOrder() 更高效
基本上就这些。Collections 的 sort 和 reverse 方法简单实用,适合大多数排序和顺序调整场景。只要注意元素可比较,并合理使用比较器,就能灵活控制集合顺序。









