Collections.copy()方法需目标列表大小不小于源列表,否则抛异常;使用时应先填充目标列表至足够大小,再执行覆盖式复制,避免直接复制空列表导致IndexOutOfBoundsException。
在Java中,Collections.copy() 方法用于将一个集合中的所有元素复制到另一个集合中。但使用时需要注意一些关键点,否则容易抛出异常或得不到预期结果。这个方法并不是创建新集合,而是将源集合的元素“覆盖式”地复制到目标集合的对应位置上。
也就是说,Collections.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]
新手常犯的错误是直接传入一个空的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 能用,但有前提条件,稍不注意就出错。理解它的“覆盖”本质,才能避免踩坑。