Collections.reverse()用于原地反转列表顺序,接收List参数并直接修改原列表,支持ArrayList、LinkedList等实现类,内部采用双指针交换实现O(n)时间与O(1)空间复杂度,适用于需高效反转的场景,若需保留原列表可先复制再反转。

在Java中,Collections.reverse() 是 Collections 工具类提供的一个静态方法,用于反转列表中元素的顺序。这个方法操作的是列表本身,不会创建新的列表,属于原地反转(in-place reversal),效率较高。
1. Collections.reverse() 基本用法
该方法接收一个实现了 List 接口的对象作为参数,调用后会将列表中的元素顺序完全颠倒。
示例代码:import java.util.*;public class ReverseExample { public static void main(String[] args) { List
list = new ArrayList<>(); list.add("A"); list.add("B"); list.add("C"); list.add("D"); System.out.println("反转前: " + list); // 输出: [A, B, C, D] Collections.reverse(list); System.out.println("反转后: " + list); // 输出: [D, C, B, A] }}
2. 支持的列表类型
只要实现了 List 接口的集合都可以使用此方法,包括:
- ArrayList
- LinkedList
- Vector
- Arrays.asList() 返回的固定大小列表(但不能改变结构)
如果使用 Arrays.asList() 创建的列表调用 reverse(),虽然可以反转内容,但不能添加或删除元素,否则会抛出 UnsupportedOperationException。
立即学习“Java免费学习笔记(深入)”;
3. 反转原理与性能分析
Collections.reverse() 的内部实现采用双指针交换策略:
- 从列表的两端同时向中间遍历
- 逐个交换首尾元素
- 时间复杂度为 O(n/2),即 O(n)
- 空间复杂度为 O(1),无需额外存储空间
for (int i = 0, j = list.size() - 1; i < j; i++, j--) {
E e = list.get(i);
list.set(i, list.get(j));
list.set(j, e);
}
4. 实际应用建议
该方法适用于需要快速反转顺序的场景,例如:
- 字符串字符列表反转
- 栈结构模拟(通过 add + reverse)
- 数据展示顺序调整(如最新记录在前)
若不想修改原列表,可先复制一份再反转:
Listoriginal = Arrays.asList(1, 2, 3); List reversed = new ArrayList<>(original); Collections.reverse(reversed);
基本上就这些。使用 Collections.reverse() 简洁高效,是处理列表反转的首选方式。










