Collections.copy()方法需目标列表大小不小于源列表,否则抛异常;使用时应先填充目标列表至足够大小,再执行覆盖式复制,避免直接复制空列表导致IndexOutOfBoundsException。

在Java中,Collections.copy() 方法用于将一个集合中的所有元素复制到另一个集合中。但使用时需要注意一些关键点,否则容易抛出异常或得不到预期结果。这个方法并不是创建新集合,而是将源集合的元素“覆盖式”地复制到目标集合的对应位置上。
方法签名与基本要求
public static- 第一个参数是目标列表(dest)
- 第二个参数是源列表(src)
- 目标列表的大小必须大于等于源列表的大小
- 如果目标列表太小,会抛出 IndexOutOfBoundsException
也就是说,Collections.copy() 不会自动扩展目标列表的容量。它只是逐个替换已有位置上的元素。
正确使用步骤
要成功使用 Collections.copy(),可以遵循以下步骤:
- 确保目标列表已经初始化,并且有足够的元素空间
- 如果目标列表为空或太小,先用占位符填充至所需长度
- 调用 Collections.copy() 执行复制
示例代码:
立即学习“Java免费学习笔记(深入)”;
Listsource = Arrays.asList("apple", "banana", "orange"); List dest = new ArrayList<>(Arrays.asList("","","")); // 预填充三个空字符串 Collections.copy(dest, source); System.out.println(dest); // 输出: [apple, banana, orange]
常见错误与规避方法
新手常犯的错误是直接传入一个空的ArrayList:
Listdest = new ArrayList<>(); // 空列表 Collections.copy(dest, source); // 抛出 IndexOutOfBoundsException
解决办法:先调整目标列表大小
Listdest = new ArrayList<>(); dest.addAll(Collections.nCopies(source.size(), null)); // 填充null Collections.copy(dest, source);
或者更安全的方式:直接用源列表构造新列表,无需copy
ListsafeCopy = new ArrayList<>(source); // 推荐方式
实际应用场景建议
Collections.copy() 更适合以下场景:
- 需要复用已有列表对象(比如缓存池中的列表)
- 性能敏感场合,避免频繁创建新对象
- 希望保留目标列表的其他元信息(如监听器、包装逻辑)
但在大多数日常开发中,直接使用 new ArrayList(src) 或 src.stream().toList() 更简单安全。
基本上就这些。Collections.copy 能用,但有前提条件,稍不注意就出错。理解它的“覆盖”本质,才能避免踩坑。










