结果:[a, b, c, d]java
[a, b, c] 工具
说明:经过addAll的方法复制一个集合,新的集合也是单独开辟了一个内存空间。固然新集合的操做不影响源集合。spa
方法三:内存
List l = new ArrayList(); it
l.add("a"); io
l.add("b"); class
l.add("c"); List
Listl2 = new ArrayList(Arrays.asList(new Object[l.size()])); 引用
Collections.copy(l2, l); 方法
l2.add("d");
System.out.println(l2);
System.out.println(l);
结果:[a, b, c, d]
[a, b, c]
说明:使用集合的工具类的静态方法Collections.copy(List desList, List srcList)的方式复制集合,获得的也是一个位于内存中不一样空间的副本。
注意这种方式,若是你直接这样写:
List l2 = new ArrayList();
Collections.copy(l2, l);
会报错:java.lang.IndexOutOfBoundsException: Source does not fit in dest
缘由是你使用该方法时,会先比较目标集合和源集合的size,而你直接new ArrayList();还没来得及复制,目标集合的size为0,和源集合的size不同,就会报错。注:new ArrayList(int size)定义的是该集合的的容纳能力为size,并非说目标集合中就有了size个元素。因此要这样写:new ArrayList(Arrays.asList(new Object[l.size()]));
方法四:
List l = new ArrayList();
l.add("a");
l.add("b");
l.add("c");
List l2 = l;
l2.add("d");
System.out.println(l2);
System.out.println(l);
结果:[a, b, c, d]
[a, b, c, d]
说明:这种方式只是定义了另外一个引用,可是指向的内容仍是源集合指向的内容。因此对其修改固然会影响源集合了。
对Map, Set的复制拷贝方式研究同理,这里再也不赘述。