Java中List反转首选Collections.reverse(),它原地反转、时间复杂度O(n)、空间O(1),但仅适用于可变List实现类,不支持Set/Map、不可变集合及基本类型数组直接转换的列表。

Java中List反转用Collections.reverse()最直接
对List类型集合做原地反转,Collections.reverse()是标准且安全的选择。它不创建新集合,只交换元素索引位置,时间复杂度O(n),空间O(1)。
注意:该方法仅接受List接口实现类(如ArrayList、LinkedList),传入Set或Map会编译报错;也不能用于不可变集合(如Arrays.asList()返回的固定大小列表,调用时抛UnsupportedOperationException)。
Listlist = new ArrayList<>(Arrays.asList("a", "b", "c")); Collections.reverse(list); // list 现在是 ["c", "b", "a"]
Stream API反转需转为ArrayList再操作
Java 8+ 的Stream本身无内置反转操作,常见错误是试图用sorted(Comparator.reverseOrder())——这只能按自然序或自定义比较器倒排,不是按插入顺序反转。
真正按原始顺序倒序,必须先收集为List,再用Collections.reverse(),或用索引反向遍历生成新列表:
立即学习“Java免费学习笔记(深入)”;
- 若需新集合且允许额外空间:用
IntStream.range(0, list.size()).mapToObj(i -> list.get(list.size() - 1 - i)).collect(Collectors.toList()) - 若原集合很大,避免
get()随机访问开销(尤其LinkedList):改用new ArrayList(list).descendingIterator()逐个取值
Arrays.asList()反转失败的典型原因
很多人写Collections.reverse(Arrays.asList(1,2,3))发现没效果或报错,根本原因是Arrays.asList()返回的是Arrays$ArrayList(非java.util.ArrayList),它不支持add()、remove(),但set()和reverse()其实可用——前提是数组本身可修改。
真正踩坑点在于:如果传入的是基本类型数组(如int[]),Arrays.asList(intArr)会把整个数组当一个元素,结果变成List,反转毫无意义;必须用包装类型数组(Integer[])或先转流:
Integer[] arr = {1, 2, 3};
List list = Arrays.asList(arr);
Collections.reverse(list); // ✅ 正常工作
// arr 现在是 {3, 2, 1} 并发集合和不可变集合不能直接反转
CopyOnWriteArrayList虽实现了List,但Collections.reverse()会触发全量复制,性能极差,不建议用;ConcurrentLinkedQueue等非List结构更无法使用该方法。
对于ImmutableList(Guava)或List.of()(Java 9+)这类不可变集合,任何修改操作都会抛UnsupportedOperationException。必须先转成可变副本:new ArrayList(immutableList),再反转。
容易被忽略的是:反转后若继续使用原引用,而原集合又被其他线程修改,可能引发数据不一致——尤其在多线程环境中,务必确认集合生命周期和共享范围。










