Java中Collections.fill方法使用解析

Collections.fill用于填充已初始化列表的所有元素为指定对象。需确保列表非空且可变,否则抛出异常;填充时共享同一引用,修改一处会影响所有元素,适用于批量赋值、重置状态等场景。

Collections.fill方法用于将指定的元素填充到列表中的所有位置,或者指定范围内的位置。这个方法不会替换原有的List结构,而是用给定的元素覆盖对应索引上的值。它适用于已经初始化且包含足够元素的List,不能用于空集合或未初始化的集合。

方法定义与参数说明

fill方法的定义如下:

public static void fill(List super T> list, T obj)

其中:

  • list:要被填充的List对象,必须是可变列表,并且已经初始化且含有至少一个元素。
  • obj:用来填充列表的元素,所有位置都将被设置为该对象的引用(注意是引用,不是副本)。

使用前提条件

调用Collections.fill前需确保以下几点:

  • 列表不能为null。
  • 列表必须已经创建并包含元素(即size > 0),否则会抛出IndexOutOfBoundsException。
  • 列表必须支持set操作,因此不可变列表(如Arrays.asList生成的固定大小列表)在某些情况下会抛出UnsupportedOperationException。

示例代码:

List list = new ArrayList<>(Arrays.asList("a", "b", "c"));
Collections.fill(list, "filled");
// 结果:["filled", "filled", "filled"]
  

注意事项

与常见问题

使用时需要注意以下几个关键点:

  • 引用共享:如果填充的是一个对象(非基本类型包装类),那么列表中每个位置都指向同一个对象实例。修改其中一个会影响其他元素。
  • 性能高效:底层通过循环调用list.set(i, obj),时间复杂度为O(n),适合中小规模数据填充。
  • 不改变大小:fill只覆盖已有元素,不会增加或减少列表长度。

错误示例:

List empty = new ArrayList<>();
Collections.fill(empty, "test"); // 抛出IndexOutOfBoundsException
  

实际应用场景

该方法常用于:

  • 初始化默认值,比如将成绩列表全部设为0。
  • 重置状态,如清空逻辑标记位为false。
  • 批量赋值简化代码,替代手动for循环。

例如:

List flags = new ArrayList<>(Collections.nCopies(10, true));
Collections.fill(flags, false); // 批量关闭标志位
  

基本上就这些。Collections.fill是一个简洁实用的方法,只要注意列表已初始化和引用共享问题,就能安全高效地使用。不复杂但容易忽略细节。