Collections.nCopies返回包含n个重复元素引用的不可变列表,所有元素共享同一实例,适用于填充默认值或测试数据,但需避免用于可变对象;若需修改应转为可变集合,如new ArrayList(Collections.nCopies(n, obj))。

在Java中,Collections.nCopies 是一个非常实用的静态方法,用于快速生成包含指定数量重复元素的不可变集合。它常用于初始化默认值、填充测试数据或简化代码逻辑。虽然使用简单,但在实际开发中仍有一些关键点需要注意,以避免潜在问题。
1. 基本用法:快速创建重复元素集合
Collections.nCopies(int n, T o) 接收两个参数:元素个数 n 和要重复的元素 o,返回一个不可变的 List,其中包含 n 个对 o 的引用。
示例:
ListSystem.out.println(defaults); // 输出: [default, default, default, default, default]
这个方法特别适合需要批量填充相同值的场景,比如初始化配置项或占位符。
立即学习“Java免费学习笔记(深入)”;
2. 注意:所有元素共享同一对象引用
生成的列表中,所有元素都指向同一个对象实例。这意味着如果元素是可变对象,修改其中一个会影响“所有”元素(实际上它们是同一个对象)。
错误示例:
List- > listOfLists = Collections.nCopies(3, new ArrayList());
listOfLists.get(0).add(1); // 修改第一个
System.out.println(listOfLists); // 所有三个都包含 [1]!
解决方案:应使用构造新对象的方式,例如通过循环或 Stream.generate() 创建独立实例。
3. 转为可变集合:避免UnsupportedOperationException
由 nCopies 返回的列表是不可变的,调用 add()、set() 等操作会抛出 UnsupportedOperationException。
若需修改,应将其复制到可变集合中:
ListmutableList.set(0, "first"); // 正常执行
这是实际开发中最常见的使用模式:先用 nCopies 快速填充,再包装成可变容器进行后续操作。
4. 适用场景与最佳实践
该方法最适合以下情况:
- 填充不可变默认值列表
- 测试中构造大量相同输入数据
- 作为其他集合操作的中间结构(如与
Arrays.asList配合)
不建议用于可变对象的批量初始化。对于复杂对象,优先考虑 Stream.generate(Supplier 或显式循环创建独立实例。
基本上就这些。掌握 Collections.nCopies 的核心在于理解其“引用共享”特性,并合理转换为可变结构使用。用得好能简化代码,用不好则容易引发隐蔽 bug。










