JavaCollections.rotate方法详解与使用示例
时间:2026-05-10 17:58:10 225浏览 收藏
Java 的 `Collections.rotate()` 是一个高效、原地操作的 List 循环移位工具——只需一行代码,就能让列表元素整体向左或向右“滚动”:正数偏移量将末尾元素循环移到前面(如 `[A,B,C,D]` 右移 1 变为 `[D,A,B,C]`),负数则将首元素移到后面;它自动对偏移量取模,支持任意大小的距离,且不创建新列表、仅需常量额外空间,但需确保传入的是可修改的 List 实现(如 ArrayList),使用前务必注意其破坏性——原列表将被直接更改。

Collections.rotate() 是 Java 集合工具类中用于对 List 进行**原地循环移位**的便捷方法。它不会创建新列表,而是直接修改原列表中元素的位置。
核心用法:指定偏移量正负决定方向
调用格式为:Collections.rotate(list, distance)
其中 distance 是整数:
- 若
distance > 0:元素**向右循环移动**(末尾元素移到前面) - 若
distance :元素**向左循环移动**(首元素移到后面) - 若
distance == 0或列表为空/单元素:无变化 - 实际位移量会自动对列表长度取模(
distance % list.size()),因此偏移量可以任意大或小
必须是可变的 List 实现
该方法要求传入的 List 支持随机访问和修改(即底层是可写的):
- ✅ 支持:
ArrayList、LinkedList(虽效率略低但可用)、Arrays.asList()返回的列表(前提是原数组非 final 且未被包装为不可变) - ❌ 不支持:
Collections.unmodifiableList()、Arrays.asList()包装的固定大小列表(若尝试修改会抛UnsupportedOperationException)
简单示例说明效果
假设初始列表为 [1, 2, 3, 4, 5]:
Collections.rotate(list, 2)→[4, 5, 1, 2, 3](右移 2 位)Collections.rotate(list, -1)→[2, 3, 4, 5, 1](左移 1 位)Collections.rotate(list, 7)等价于rotate(list, 2)(因为 7 % 5 = 2)
注意事项与常见误区
使用时需注意:
- 操作是**破坏性**的——原列表内容被直接更改,如需保留原顺序,请先
new ArrayList(originalList)复制一份 - 不适用于
Set或Map,仅限List - 对
null列表会抛NullPointerException;对null元素本身无影响 - 时间复杂度为 O(n),空间复杂度为 O(1)
今天关于《JavaCollections.rotate方法详解与使用示例》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
264 收藏
-
234 收藏
-
434 收藏
-
192 收藏
-
162 收藏
-
225 收藏
-
437 收藏
-
152 收藏
-
125 收藏
-
184 收藏
-
401 收藏
-
398 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习