Java里如何使用Collections工具类排序和反转集合_Collections排序与反转方法解析

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按字母顺序排序:
Listwords = new ArrayList();
words.add("banana");
words.add("apple");
words.add("cherry");
Collections.sort(words); // 默认升序
System.out.println(words); // 输出 [apple, banana, cherry]
  • 对自定义对象排序,比如按年龄排序的Person类:
class Person {
    String name;
    int a

ge;
    Person(String name, int age) { this.name = name; this.age = age; }
}

List people = Arrays.asList(
    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中元素的顺序完全颠倒。它不会进行排序,只是把原有顺序反过来。

示例:

List numbers = new ArrayList();
numbers.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反向比较。

  • 方式一:排序后反转(简单直观)
List list = Arrays.asList(5, 2, 8, 1);
Collections.sort(list); // 升序 [1, 2, 5, 8]
Collections.reverse(list); // 反转 [8, 5, 2, 1]
  • 方式二:使用 Comparator.reverseOrder() 更高效
Collections.sort(list, Comparator.reverseOrder()); // 直接降序

基本上就这些。Collections 的 sort 和 reverse 方法简单实用,适合大多数排序和顺序调整场景。只要注意元素可比较,并合理使用比较器,就能灵活控制集合顺序。