登录
首页 >  文章 >  java教程

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() 将集合中的元素按照指定的偏移量进行循环位置移动

Collections.rotate() 是 Java 集合工具类中用于对 List 进行**原地循环移位**的便捷方法。它不会创建新列表,而是直接修改原列表中元素的位置。

核心用法:指定偏移量正负决定方向

调用格式为:
Collections.rotate(list, distance)
其中 distance 是整数:

  • distance > 0:元素**向右循环移动**(末尾元素移到前面)
  • distance :元素**向左循环移动**(首元素移到后面)
  • distance == 0 或列表为空/单元素:无变化
  • 实际位移量会自动对列表长度取模(distance % list.size()),因此偏移量可以任意大或小

必须是可变的 List 实现

该方法要求传入的 List 支持随机访问和修改(即底层是可写的):

  • ✅ 支持:ArrayListLinkedList(虽效率略低但可用)、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) 复制一份
  • 不适用于 SetMap,仅限 List
  • null 列表会抛 NullPointerException;对 null 元素本身无影响
  • 时间复杂度为 O(n),空间复杂度为 O(1)

今天关于《JavaCollections.rotate方法详解与使用示例》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>