Collections.fill用于填充已初始化列表的所有元素为指定对象。需确保列表非空且可变,否则抛出异常;填充时共享同一引用,修改一处会影响所有元素,适用于批量赋值、重置状态等场景。
Collections.fill方法用于将指定的元素填充到列表中的所有位置,或者指定范围内的位置。这个方法不会替换原有的List结构,而是用给定的元素覆盖对应索引上的值。它适用于已经初始化且包含足够元素的List,不能用于空集合或未初始化的集合。
fill方法的定义如下:
public static其中:
调用Collections.fill前需确保以下几点:
示例代码:
Listlist = new ArrayList<>(Arrays.asList("a", "b", "c")); Collections.fill(list, "filled"); // 结果:["filled", "filled", "filled"]
使用时需要注意以下几个关键点:
错误示例:
Listempty = new ArrayList<>(); Collections.fill(empty, "test"); // 抛出IndexOutOfBoundsException
该方法常用于:
例如:
Listflags = new ArrayList<>(Collections.nCopies(10, true)); Collections.fill(flags, false); // 批量关闭标志位
基本上就这些。Collections.fill是一个简洁实用的方法,只要注意列表已初始化和引用共享问题,就能安全高效地使用。不复杂但容易忽略细节。