照常,先来看看Collections.unmodifiableMap()的API:
unmodifiableSortedMap
public static <K,V> SortedMap<K,V> unmodifiableSortedMap(SortedMap<K,? extends V> m)
-
返回指定有序映射的不可修改视图。此方法允许模块为用户提供对内部有序映射的“只读”访问。在返回的有序映射上执行的查询操作将“读完”指定的有序映射。试图修改返回的有序映射(无论是直接修改、通过其 collection 视图修改,还是通过其
subMap、
headMap或
tailMap视图修改)将导致抛出
UnsupportedOperationException。
如果指定的有序映射是可序列化的,则返回的有序映射也将是可序列化的。
-
-
参数:
-
m
- 将为其返回一个不可修改视图的有序映射。
返回:
- 指定有序映射的不可修改视图。
-
- package go.jacob.day729;
-
- import java.util.Collections;
- import java.util.HashMap;
- import java.util.Map;
-
- public class Demo5 {
- public static void main(String[] args) {
- Map<Integer,StringBuilder> map=new HashMap<Integer,StringBuilder>();
- map.put(1,new StringBuilder("c1"));
- map.put(2,new StringBuilder("c2"));
- map.put(3,new StringBuilder("c3"));
-
- Map<Integer,StringBuilder> unmodifiableMap=Collections.unmodifiableMap(map);
- //这时候如果再往unmodifiableMap中添加元素,会发生错误
- //unmodifiableMap.put(4,new StringBuilder("c4"));
-
-
-
- }
- }
运行结果如下:
但是,由于map中的value是StringBuilder类型,是可变对象,所以依然可以对key进行修改。看如下代码:
- package go.jacob.day729;
-
- import java.util.Collections;
- import java.util.HashMap;
- import java.util.Map;
-
- public class Demo5 {
- public static void main(String[] args) {
- Map<Integer,StringBuilder> map=new HashMap<Integer,StringBuilder>();
- map.put(1,new StringBuilder("c1"));
- map.put(2,new StringBuilder("c2"));
- map.put(3,new StringBuilder("c3"));
-
- Map<Integer,StringBuilder> unmodifiableMap=Collections.unmodifiableMap(map);
- //这时候如果再往unmodifiableMap中添加元素,会发生错误
- //unmodifiableMap.put(4,new StringBuilder("c4"));
-
- unmodifiableMap.get(3).append("new");
- System.out.println(unmodifiableMap.get(3));
-
- }
- }
运行结果:
最后一个问题,如果修改原map中的对象,是否会影响到unmodifiableMap呢?直接看结果
- map.get(1).append("new");
- System.out.println(unmodifiableMap.get(1));
结果:
很显然,结果改变了,所以我们认为这是对map对象的深拷贝(深拷贝和浅拷贝的概念,大家可以上网搜一下,或者参考一下我这篇博客:http://blog.csdn.net/zjkc050818/article/details/76098354)
转载于:https://blog.csdn.net/zjkC050818/article/details/76325665