怎么确保一个集合不能被修改?

我们很容易想到用final关键字进行修饰,我们都知道

final关键字可以修饰类,方法,成员变量,final修饰的类不能被继承,final修饰的方法不能被重写,final修饰的成员变量必须初始化值,如果这个成员变量是基本数据类型,表示这个变量的值是不可改变的,如果说这个成员变量是引用类型,则表示这个引用的地址值是不能改变的,但是这个引用所指向的对象里面的内容还是可以改变的

那么,我们怎么确保一个集合不能被修改?首先我们要清楚,集合(map,set,list…)都是引用类型,所以我们如果用final修饰的话,集合里面的内容还是可以修改的。

我们可以做一个实验:
在这里插入图片描述
可以看到:我们用final关键字定义了一个map集合,这时候我们往集合里面传值,第一个键值对1,1;我们再修改后,可以把键为1的值改为100,说明我们是可以修改map集合的值的。

那我们应该怎么做才能确保集合不被修改呢?
我们可以采用Collections包下的unmodifiableMap方法,通过这个方法返回的map,是不可以修改的。他会报 java.lang.UnsupportedOperationException错。
在这里插入图片描述
同理:Collections包也提供了对list和set集合的方法。
Collections.unmodifiableList(List)
Collections.unmodifiableSet(Set)

确保一个集合不能修改,可以考虑以下两种方式: 1. 使用不可变集合(Immutable Collection):Java 提供了一些不可变集合类,如 `Collections.unmodifiableList()`, `Collections.unmodifiableSet()`, `Collections.unmodifiableMap()` 等。这些方法返回的集合是只读的,任何对其进行修改的操作都会抛出 UnsupportedOperationException 异常。 示例代码: ```java List<String> originalList = new ArrayList<>(); originalList.add("A"); originalList.add("B"); originalList.add("C"); List<String> unmodifiableList = Collections.unmodifiableList(originalList); unmodifiableList.add("D"); // 抛出 UnsupportedOperationException ``` 2. 使用只读视图(Read-only View):如果使用的是某些集合实现类,如 `ArrayList`、`HashSet` 等,可以通过将其转换为只读视图来防止修改。这可以通过将集合对象传递给构造函数或使用特定的方法来实现,如 `Collections.unmodifiableCollection()`。 示例代码: ```java List<String> originalList = new ArrayList<>(); originalList.add("A"); originalList.add("B"); originalList.add("C"); Collection<String> readOnlyCollection = Collections.unmodifiableCollection(originalList); readOnlyCollection.add("D"); // 抛出 UnsupportedOperationException ``` 使用这两种方式可以确保集合对象在其他地方无法进行修改,从而提供更强的安全性和保护。注意,虽然集合本身不能修改,但如果集合中包含可变对象,则这些对象的状态仍然可以被修改
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值