在Java中如何使用Collections.copy复制集合_Collections复制技巧解析

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

在Java中,Collections.copy() 方法用于将一个集合中的所有元素复制到另一个集合中,目标集合的大小必须大于或等于源集合。这个方法不会自动扩容目标集合,也不会添加新元素,而是覆盖已有

位置的元素。

理解 Collections.copy() 的基本用法

Collections.copy()java.util.Collections 类中的静态方法,其定义如下:

public static void copy(List super T> dest, List extends T> src)

它接受两个参数:

  • src:源列表,提供要复制的数据
  • dest:目标列表,接收复制的数据(必须足够大)

注意:目标列表的大小不能小于源列表,否则会抛出 IndexOutOfBoundsException

正确使用 copy 方法的步骤

由于 Collections.copy() 要求目标列表已有足够的容量,通常需要先初始化目标列表的大小。

示例代码:

List source = 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) 快速填充初始值

常见错误与规避方式

最常见的问题是目标列表容量不足:

List src = Arrays.asList("a", "b");
List dst = new ArrayList<>();
// Collections.copy(dst, src); // 运行时抛异常

正确做法:

List dst = new ArrayList<>(Collections.nCopies(src.size(), null));
Collections.copy(dst, src);

或者更简洁地创建副本:

List safeCopy = new ArrayList<>(src); // 直接构造更简单

与其它复制方式的对比

Collections.copy() 并非常用的集合复制手段,更多是用于特定场景下的批量覆盖操作。

  • 若只是想复制列表,推荐使用 new ArrayList(original)
  • 若需保持引用同步,可考虑 Collections.unmodifiableList()
  • Collections.copy() 更适合“预分配缓存池”类场景,如对象池重用

基本上就这些。虽然 Collections.copy() 看似简单,但容易因忽略容量问题而出错。掌握它的前提是理解它不扩容、只覆写的本质行为。日常开发中,多数情况下直接构造新列表更安全便捷。