Collections.unmodifiableList返回不可修改的列表视图,防止外部代码修改列表内容。传入现有List后,返回的新视图禁止添加、删除或更新元素,否则抛出UnsupportedOperationException;但原始列表仍可变,其变化会同步至视图。为彻底保护数据,应将原始列表设为私有并提供unmodifiableList包装的只读访问,如在StudentManager类中封装students列表,确保内部数据安全。该方法适用于共享数据且需防止写操作的场景,提升程序安全与封装性。
在Java中,Collections.unmodifiableList 方法用于创建一个不可修改的列表视图。这意味着你不能对通过该方法返回的列表进行添加、删除或更新元素等操作。这个方法常用于保护原始数据不被外部代码意外修改。
调用 Colle
ctions.unmodifiableList 时,传入一个已存在的 List 对象,它会返回一个新的不可变视图:
ListoriginalList = new ArrayList<>(); originalList.add("A"); originalList.add("B"); List unmodifiableList = Collections.unmodifiableList(originalList); // 下面的操作会抛出 UnsupportedOperationException // unmodifiableList.add("C"); // ❌ 不允许 // unmodifiableList.remove(0); // ❌ 不允许
注意:不可变的是返回的视图,而不是原始列表。如果你通过原始列表(originalList)修改内容,不可变视图也会反映出这些变化:
originalList.add("C");
System.out.println(unmodifiableList); // 输出 [A, B, C],视图同步更新
如果希望彻底防止列表被修改,需要确保原始列表也无法被更改。常见做法是创建一个“私有且不可变”的副本:
public class StudentManager {
private final List students = new ArrayList<>();
public StudentManager() {
students.add("Alice");
students.add("Bob");
}
// 只提供只读访问
public List getStudents() {
return Collections.unmodifiableList(students);
}
}
这样即使外部调用 getStudents(),也无法修改内部的 students 列表。