参考
Collections.unmodifiableSortedMap:
返回指定有序映射的不可修改视图,提供对内部有序映射的“只读”访问。试图修改返回的有序映射将导致抛出 UnsupportedOperationException。
如果指定的有序映射是可序列化的,则返回的有序映射也将是可序列化的。
Collections.unmodifiableMap():只是无序的区别
例子:
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进行修改。看如下代码:
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)