Java的List中的各种浅拷贝和深拷贝问题
先来看一组代码
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());
}
}
注意:拷贝的过程中,长度一定要把控好,不要溢出,不会自动扩容的