0

0

在Java中如何使用Collections.reverse方法反转集合_Java集合反转方法说明

P粉602998670

P粉602998670

发布时间:2026-02-05 12:55:40

|

332人浏览过

|

来源于php中文网

原创

Collections.reverse()仅适用于List,对Set或Map编译失败;它是就地反转,不创建新列表;泛型安全但需确保元素类型一致;时间复杂度O(n/2),大数据量可手动swap优化。

在java中如何使用collections.reverse方法反转集合_java集合反转方法说明

reverse 方法只能反转 List,不能用于 Set 或 Map

Collections.reverse() 是 Java 集合工具类中的静态方法,但它只接受 List 类型参数。传入 SetMap 或其他非 List 实现会直接编译失败——因为方法签名明确是 public static void reverse(List> list)

常见误用场景包括:试图对 HashSetTreeSet 调用该方法,或把 map.keySet()(返回 Set)直接传进去。这类操作连编译都过不去,错误信息通常是:The method reverse(List>) in the type Collections is not applicable for the arguments (Set<...>)

如果真需要“反转”非 List 集合,得先转成 List,例如:new ArrayList(set),再调用 reverse();但要注意这仅反转副本,不改变原集合结构。

原地反转,不创建新 List

Collections.reverse() 是就地操作(in-place),它直接修改传入的 List 对象内部元素顺序,不返回新列表,也不改变原对象引用。

立即学习Java免费学习笔记(深入)”;

这意味着:

  • 如果传入的是 Arrays.asList() 返回的固定大小列表,反转后原数组内容也会被改写(因为底层共享数组)
  • 如果传入的是 new ArrayList(original) 的副本,那只是副本被反转,原集合不受影响
  • 如果传入的是不可变列表(如 Lists.newArrayList() 来自 Guava,或 List.of() 创建的不可变实例),运行时会抛出 UnsupportedOperationException

示例:

String[] arr = {"a", "b", "c"};
List list = Arrays.asList(arr);
Collections.reverse(list);
// 此时 arr == {"c", "b", "a"},因为 list 和 arr 共享底层数组

泛型擦除不影响使用,但需注意运行时类型安全

Collections.reverse() 声明为 reverse(List>),所以能接受任意类型的 List,比如 ListList,甚至原始类型数组包装的 List。编译器不会报泛型警告。

不过要注意:虽然方法不关心具体类型,但如果 List 中混入了不同类型的对象(比如手动往 List 里 add 了 String 和 Integer),反转本身仍能成功——它只交换引用位置,不校验类型。真正出问题往往在后续遍历时发生 ClassCastException

所以反转前最好确认 List 是类型安全的,尤其是从外部接收或反射构造的集合。

性能和替代方案:小列表够用,大数据量可考虑 Collections.swap

Collections.reverse() 时间复杂度是 O(n/2),内部用双指针遍历一半长度,逐个调用 swap()。对大多数业务场景(几千以内元素)完全够用。

但如果要频繁反转、或在性能敏感路径(如实时数据处理循环中),可以自己用 Collections.swap(list, i, list.size()-1-i) 手动控制,避免方法调用开销;或者对只读场景,用 Lists.reverse(list)(Guava)返回一个视图,不实际移动元素。

另外注意:LinkedList 反转比 ArrayList 略慢,因为每次 get(i) 在链表中是 O(n) 操作,而 reverse() 内部依赖 set()get() —— 所以对大 LinkedList,建议先转成 ArrayList 再反转。

最常被忽略的一点是:很多人以为 reverse() 能“撤销排序”,其实它只是按当前顺序倒放,和是否有序无关。如果你刚用 Collections.sort() 排过序,再反转确实能得到降序效果;但如果原列表是乱序的,反转后还是乱序,只是顺序颠倒而已。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
guava包作用
guava包作用

guava是一个java库,增强了java标准库,提供更有效率和易于使用的集合、实用程序、缓存和并发工具。想了解更多guava的相关内容,可以阅读本专题下面的文章。

264

2024.05.29

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

585

2023.08.02

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

396

2023.09.04

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

178

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

107

2025.11.27

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

64

2025.11.17

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

7

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.2万人学习

C# 教程
C# 教程

共94课时 | 8.6万人学习

Java 教程
Java 教程

共578课时 | 57.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号