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

Collections.fill方法用于将指定的元素填充到列表中的所有位置,或者指定范围内的位置。这个方法不会替换原有的List结构,而是用给定的元素覆盖对应索引上的值。它适用于已经初始化且包含足够元素的List,不能用于空集合或未初始化的集合。
方法定义与参数说明
fill方法的定义如下:
public static其中:
- list:要被填充的List对象,必须是可变列表,并且已经初始化且含有至少一个元素。
- obj:用来填充列表的元素,所有位置都将被设置为该对象的引用(注意是引用,不是副本)。
使用前提条件
调用Collections.fill前需确保以下几点:
立即学习“Java免费学习笔记(深入)”;
- 列表不能为null。
- 列表必须已经创建并包含元素(即size > 0),否则会抛出IndexOutOfBoundsException。
- 列表必须支持set操作,因此不可变列表(如Arrays.asList生成的固定大小列表)在某些情况下会抛出UnsupportedOperationException。
示例代码:
用 php + mysql 驱动的在线商城系统,我们的目标为中国的中小企业及个人提供最简洁,最安全,最高效的在线商城解决方案,使用了自建的会员积分折扣功能,不同的会员组有不同的折扣,让您的商店吸引更多的后续客户。 系统自动加分处理功能,自动处理会员等级,免去人工处理的工作量,让您的商店运作起来更方便省事 采用了自建的直接模板技术,免去了模板解析时间,提高了代码利用效率 独立开发的购物车系统,使用最
Listlist = new ArrayList<>(Arrays.asList("a", "b", "c")); Collections.fill(list, "filled"); // 结果:["filled", "filled", "filled"]
注意事项与常见问题
使用时需要注意以下几个关键点:
- 引用共享:如果填充的是一个对象(非基本类型包装类),那么列表中每个位置都指向同一个对象实例。修改其中一个会影响其他元素。
- 性能高效:底层通过循环调用list.set(i, obj),时间复杂度为O(n),适合中小规模数据填充。
- 不改变大小:fill只覆盖已有元素,不会增加或减少列表长度。
错误示例:
Listempty = new ArrayList<>(); Collections.fill(empty, "test"); // 抛出IndexOutOfBoundsException
实际应用场景
该方法常用于:
- 初始化默认值,比如将成绩列表全部设为0。
- 重置状态,如清空逻辑标记位为false。
- 批量赋值简化代码,替代手动for循环。
例如:
Listflags = new ArrayList<>(Collections.nCopies(10, true)); Collections.fill(flags, false); // 批量关闭标志位
基本上就这些。Collections.fill是一个简洁实用的方法,只要注意列表已初始化和引用共享问题,就能安全高效地使用。不复杂但容易忽略细节。









