Collections.copy()用于将源列表元素复制到已有目标列表中,要求目标列表长度≥源列表。示例中通过预填充默认值确保容量,调用copy后完成覆盖复制。常见错误包括目标列表长度不足或未初始化,会抛出IndexOutOfBoundsException或NullPointerException。注意其与addAll()区别:copy是替换原有元素位置,不改变结构;addAll是追加元素,增加长度。需提前设置目标列表大小,可用Collections.nCopies初始化。该方法适用于复用列表对象的场景,如性能敏感环境。

在Java中,Collections.copy() 方法用于将一个列表(List)中的元素复制到另一个已有列表中,目标列表的长度必须大于或等于源列表。这个方法并不会创建新列表,而是将源列表的元素逐个覆盖到目标列表的对应位置上。
理解 Collections.copy() 的基本用法
Collections.copy() 是 java.util.Collections 类提供的静态方法,其定义如下:
public static其中:
- src:源列表,提供要复制的数据
- dest:目标列表,接收复制的数据,必须已有足够容量
注意:目标列表的大小不能小于源列表,否则会抛出 IndexOutOfBoundsException。
立即学习“Java免费学习笔记(深入)”;
使用步骤与示例代码
要正确使用 Collections.copy(),需按以下步骤操作:
- 确保目标列表已初始化,并且元素数量 ≥ 源列表
- 通常使用 Collections.fill() 或构造时填充默认值来预设目标列表大小
- 调用 Collections.copy(dest, src)
示例代码:
import java.util.*;
public class CollectionsCopyExample {
public static void main(String[] args) {
// 源列表
List source = Arrays.asList("apple", "banana", "cherry");
// 目标列表必须有足够大小
List destination = new ArrayList<>();
for (int i = 0; i < source.size(); i++) {
destination.add("default");
}
// 执行复制
Collections.copy(destination, source);
System.out.println("源列表: " + source);
System.out.println("目标列表: " + destination);
}
}
输出结果:
源列表: [apple, banana, cherry]目标列表: [apple, banana, cherry]
常见错误与注意事项
使用 Collections.copy() 时容易遇到以下几个问题:
- 目标列表为空或长度不足 → 抛出 IndexOutOfBoundsException
- 目标列表未初始化 → NullPointerException
- 误以为 copy() 会自动扩容 → 实际不会,必须提前设置好大小
避免方式:始终确保目标列表长度足够。可借助如下方式初始化:
destination = new ArrayList(Collections.nCopies(source.size(), null));与 List.addAll() 的区别
很多人混淆 Collections.copy() 和 list.addAll(),它们的核心区别在于:
- Collections.copy():替换目标列表中已有元素的位置,不改变其结构
- list.addAll():将元素追加到列表末尾,增加列表长度
如果只是想“复制一份数据”,使用 new ArrayList(source) 更直接;而 Collections.copy() 更适用于需要复用已有列表对象的场景,比如性能敏感或对象池环境。
基本上就这些。掌握 Collections.copy 的前提条件和使用限制,能有效避免运行时异常,提升集合操作的稳定性。










