Collections.fill()用于将List中所有元素替换为指定对象。需确保集合为已初始化的List且size>0,支持null值填充,直接修改原集合,时间复杂度O(n),适用于ArrayList等可变列表,不适用于Set或Map。

在Java中,Collections.fill() 是一个静态方法,用于将指定集合中的所有元素替换为同一个指定对象。这个方法适用于已初始化且包含元素的集合,能高效实现批量替换操作。
方法签名与参数说明
public static- list:要填充的目标List集合,不能为空,否则抛出NullPointerException
- obj:用来填充集合的元素值,可以是任意对象(包括null)
使用前提条件
使用 Collections.fill() 前需注意以下几点:
- 目标集合必须是 List 接口的实现类(如 ArrayList、LinkedList 等)
- 集合必须已经初始化,并且包含至少一个元素(size > 0),否则不会有任何效果
- 不能用于 Set、Map 或其他非List集合类型
- 如果集合容量为0,调用fill不会报错但也不会改变任何内容
实际使用示例
下面是一个简单的代码示例展示如何使用 Collections.fill:
ListSystem.out.println("替换前:" + list);
Collections.fill(list, "X");
System.out.println("替换后:" + list);
输出结果:
立即学习“Java免费学习笔记(深入)”;
替换前:[a, b, c]替换后:[X, X, X]
也可以填充 null 值:
Collections.fill(list, null); // 所有元素变为 null注意事项与常见问题
- 该方法直接修改原集合,不会创建新集合
- 所有元素引用都指向同一个对象(即传入的 obj),若该对象可变需小心共享引用带来的副作用
- 性能高,时间复杂度为 O(n),内部通过循环赋值实现
- 不适用于不可变列表(如 Arrays.asList 创建的固定大小列表在添加或删除时会报错,但 fill 可以执行)










