先来看一组代码
public class Temp{public static void main(String[] args) {List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);List<Integer> temp = list;list.add(4);System.out.println(list.toString());System.out.println(temp.toString());}
}
运行结果为:
[1, 2, 3, 4]
[1, 2, 3, 4]
这表明temp是指向的list的地址而不是拷贝了完整的一份是浅拷贝,那么我们如何才能让双方互不影响。
先来看看基本数据类型。这里参考ArrayList源码里面的拷贝实现过程。
import java.util.*;public class Temp{public static void main(String[] args) {int[] a = new int[5];a[0]=1;a[1]=2;a[2]=3;a[3]=4;int[] b= a;a[4]=9;for(int x:a)System.out.print(x);System.out.println();for(int x:b)System.out.print(x);}
}
结果也是相同的情况
12349
12349
我们知道ArrayList源码里主要用到了两个拷贝函数分别是Arrays.copyOf()和System.arraycopy()
import java.util.*;public class Temp{public static void main(String[] args) {int[] a = new int[5];a[0]=1;a[1]=2;a[2]=3;a[3]=4;int[] b= Arrays.copyOf(a, a.length);a[4]=9;for(int x:a)System.out.print(x);System.out.println();for(int x:b)System.out.print(x);}
}
import java.util.*;public class Temp{public static void main(String[] args) {int[] a = new int[5];int[] b = new int[5];a[0]=1;a[1]=2;a[2]=3;a[3]=4;System.arraycopy(a, 0, b, 0, a.length);;a[4]=9;for(int x:a)System.out.print(x);System.out.println();for(int x:b)System.out.print(x);}
}
这两个结果都是
12349
12340
实现了深拷贝
再回到List,我们可以使用Collections.copy实现深拷贝
public class Temp{public static void main(String[] args) {List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);List<Integer> temp = new ArrayList<>();temp.add(2);temp.add(3);temp.add(4);Collections.copy(temp, list);;list.add(4);System.out.println(list.toString());System.out.println(temp.toString());}
}
注意:拷贝的过程中,长度一定要把控好,不要溢出,不会自动扩容的