Java中Collections.reverse列表反转

Collections.reverse()用于反转列表元素顺序,直接修改原列表。示例中字符串列表[Alice, Bob, Charlie]经反转后变为[Charlie, Bob, Alice],操作原地执行,时间复杂度O(n),支持ArrayList、LinkedList等可变列表,不可变列表会抛异常,自定义对象列表同样适用,需保持原列表时应先复制再反转。

在Java中,Collections.reverse() 是一个静态方法,用于反转列表中元素的顺序。这个方法属于 java.util.Collections 类,使用起来非常简单,不需要手动编写循环或交换逻辑。

方法签名

public static void reverse(List> list)

该方法直接修改传入的列表,不返回新的列表,返回类型是 void

使用示例

下面是一个简单的例子,演示如何使用 Collections.reverse() 反转一个字符串列表:

import java.util.*;

public class ReverseExample {
    public static void main(String[] args) {
        List names = new ArrayList<>();
        names.add("Alice");
        names.add("Bob");
        names.add("Charlie");

        System.out.println("反转前: " + names);
        Collections.reverse(names);
        System.out.println("反转后: " + names);
    }
}

输出结果为:
反转前: [Alice, Bob, Charlie]
反转后: [Charlie, Bob, Alice]

注意事项

  • 列表必须是可修改的。如果传入的是不可变列表(如通过 Collections.unmodifiableList() 创建

    ),会抛出 UnsupportedOperationException
  • 支持任何实现了 List 接口的集合,比如 ArrayListLinkedList 等。
  • 该操作是原地反转,即直接修改原列表,不会创建新对象。
  • 时间复杂度为 O(n),性能良好。

反转自定义对象列表

你也可以反转包含自定义对象的列表。只要列表实现了 List 接口,Collections.reverse() 就能正常工作:

List people = Arrays.asList(
    new Person("张三"),
    new Person("李四"),
    new Person("王五")
);
Collections.reverse(people); // 同样适用

注意:如果你希望保留原列表不变,可以先复制一份再反转:

List original = Arrays.asList("a", "b", "c");
List reversed = new ArrayList<>(original);
Collections.reverse(reversed);

基本上就这些。Collections.reverse 使用简单,适合大多数需要反转列表的场景。