Collections.replaceAll用于将List中所有等于oldVal的元素替换为newVal,基于equals方法比较,成功替换至少一个元素则返回true。

在Java中,Collections.replaceAll 方法用于将列表(List)中的某个指定元素全部替换为另一个元素。这个方法属于 java.util.Collections 工具类,使用起来简单高效,适用于任何实现了 List 接口的集合,比如 ArrayList、LinkedList 等。
方法签名
public static该方法会遍历整个列表,把所有等于 oldVal 的元素替换为 newVal。如果成功替换了至少一个元素,返回 true;否则返回 false。注意:比较是基于对象的 equals() 方法进行的。
基本使用示例
假设有一个字符串列表,想把所有的 "apple" 替换为 "orange":
Listfruits.add("apple");
fruits.add("banana");
fruits.add("apple");
fruits.add("cherry");
boolean result = Collections.replaceAll(fruits, "apple", "orange");
System.out.println(fruits); // 输出: [orange, banana, orange, cherry]
System.out.println(result); // 输出: true
在这个例子中,两个 "apple" 都被成功替换,方法返回 true。
免费 盛世企业网站管理系统(SnSee)系统完全免费使用,无任何功能模块使用限制,在使用过程中如遇到相关问题可以去官方论坛参与讨论。开源 系统Web代码完全开源,在您使用过程中可以根据自已实际情况加以调整或修改,完全可以满足您的需求。强大且灵活 独创的多语言功能,可以直接在后台自由设定语言版本,其语言版本不限数量,可根据自已需要进行任意设置;系统各模块可在后台自由设置及开启;强大且适用的后台管理支
立即学习“Java免费学习笔记(深入)”;
注意事项和限制
- 只适用于 List 类型,不能用于 Set、Map 或其他集合类型。
- 替换基于 equals() 比较,因此自定义对象需要正确重写 equals 方法才能准确匹配。
- 如果 oldVal 为 null,方法仍可正常工作,会把所有 null 元素替换为 newVal。
- 若列表不可修改(如通过 Collections.unmodifiableList 创建),调用此方法会抛出 UnsupportedOperationException。
对自定义对象的替换
如果你的列表中存储的是自定义对象,确保该类正确实现了 equals() 方法:
class Person {String name;
int age;
Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof Person)) return false;
Person p = (Person) o;
return age == p.age && Objects.equals(name, p.name);
}
}
List
people.add(new Person("Alice", 25));
people.add(new Person("Bob", 30));
people.add(new Person("Alice", 25));
Person oldPerson = new Person("Alice", 25);
Person newPerson = new Person("Charlie", 25);
Collections.replaceAll(people, oldPerson, newPerson);
由于 Person 正确实现了 equals,两个同名同年龄的对象会被识别为相等,从而完成替换。
基本上就这些。只要注意集合类型和 equals 行为,Collections.replaceAll 是一个简洁实用的批量替换工具。









