Collections.copy()要求目标列表大小不小于源列表,否则抛出IndexOutOfBoundsException;需先初始化目标列表容量,如使用Collections.nCopies填充,再执行复制,适用于预分配场景,但日常更推荐new ArrayList(src)方式直接构造副本。

在Java中,Collections.copy() 方法用于将一个集合中的所有元素复制到另一个集合中,目标集合的大小必须大于或等于源集合。这个方法不会自动扩容目标集合,也不会添加新元素,而是覆盖已有位置的元素。
理解 Collections.copy() 的基本用法
Collections.copy() 是 java.util.Collections 类中的静态方法,其定义如下:
public static
它接受两个参数:
立即学习“Java免费学习笔记(深入)”;
- src:源列表,提供要复制的数据
- dest:目标列表,接收复制的数据(必须足够大)
注意:目标列表的大小不能小于源列表,否则会抛出 IndexOutOfBoundsException。
正确使用 copy 方法的步骤
由于 Collections.copy() 要求目标列表已有足够的容量,通常需要先初始化目标列表的大小。
示例代码:
Listsource = Arrays.asList("apple", "banana", "orange"); List dest = new ArrayList<>(Arrays.asList("","","")); // 预设三个空位 Collections.copy(dest, source); System.out.println(dest); // 输出 [apple, banana, orange]
关键点:
- 目标列表 dest 必须已经包含至少与源列表相同数量的元素
- 如果 dest 初始化为
new ArrayList(),直接调用会报错 - 可以使用
Collections.nCopies(n, null)快速填充初始值
常见错误与规避方式
最常见的问题是目标列表容量不足:
Listsrc = Arrays.asList("a", "b"); List dst = new ArrayList<>(); // Collections.copy(dst, src); // 运行时抛异常
正确做法:
Listdst = new ArrayList<>(Collections.nCopies(src.size(), null)); Collections.copy(dst, src);
或者更简洁地创建副本:
ListsafeCopy = new ArrayList<>(src); // 直接构造更简单
与其它复制方式的对比
Collections.copy() 并非常用的集合复制手段,更多是用于特定场景下的批量覆盖操作。
- 若只是想复制列表,推荐使用
new ArrayList(original) - 若需保持引用同步,可考虑
Collections.unmodifiableList() - Collections.copy() 更适合“预分配缓存池”类场景,如对象池重用
基本上就这些。虽然 Collections.copy() 看似简单,但容易因忽略容量问题而出错。掌握它的前提是理解它不扩容、只覆写的本质行为。日常开发中,多数情况下直接构造新列表更安全便捷。










