Bun*_*bbs 58 java arrays clone
当在数组上使用时,Java中的clone()方法究竟返回了什么?它是否返回一个包含从原始数据复制的数据的新数组?
例如:
int[] a = {1,2,3};
int[] b = a.clone();
Run Code Online (Sandbox Code Playgroud)
Kev*_*sox 88
当在clone
数组上调用该方法时,它返回对新数组的引用,该数组包含(或引用)与源数组相同的元素.
因此,在您的示例中,int[] a
是在堆上创建的单独对象实例,并且int[] b
是在堆上创建的单独对象实例.(记住所有数组都是对象).
int[] a = {1,2,3};
int[] b = a.clone();
System.out.println(a == b ? "Same Instance":"Different Instance");
//Outputs different instance
Run Code Online (Sandbox Code Playgroud)
如果要修改,int[] b
则不会反映出更改,int[] a
因为这两个是单独的对象实例.
b[0] = 5;
System.out.println(a[0]);
System.out.println(b[0]);
//Outputs: 1
// 5
Run Code Online (Sandbox Code Playgroud)
当源数组包含对象时,这会变得稍微复杂一些.该clone
方法将返回对新数组的引用,该数组引用与源数组相同的对象.
所以,如果我们有班级Dog
......
class Dog{
private String name;
public Dog(String name) {
super();
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
Run Code Online (Sandbox Code Playgroud)
我创建并填充一个类型的数组Dog
...
Dog[] myDogs = new Dog[4];
myDogs[0] = new Dog("Wolf");
myDogs[1] = new Dog("Pepper");
myDogs[2] = new Dog("Bullet");
myDogs[3] = new Dog("Sadie");
Run Code Online (Sandbox Code Playgroud)
然后克隆狗......
Dog[] myDogsClone = myDogs.clone();
Run Code Online (Sandbox Code Playgroud)
数组指的是相同的元素......
System.out.println(myDogs[0] == myDogsClone[0] ? "Same":"Different");
System.out.println(myDogs[1] == myDogsClone[1] ? "Same":"Different");
System.out.println(myDogs[2] == myDogsClone[2] ? "Same":"Different");
System.out.println(myDogs[3] == myDogsClone[3] ? "Same":"Different");
//Outputs Same (4 Times)
Run Code Online (Sandbox Code Playgroud)
这意味着如果我们修改通过克隆数组访问的对象,当我们访问源数组中的同一对象时,将反映更改,因为它们指向相同的引用.
myDogsClone[0].setName("Ruff");
System.out.println(myDogs[0].getName());
//Outputs Ruff
Run Code Online (Sandbox Code Playgroud)
但是,对阵列本身的更改只会影响该阵列.
myDogsClone[1] = new Dog("Spot");
System.out.println(myDogsClone[1].getName());
System.out.println(myDogs[1].getName());
//Outputs Spot
// Pepper
Run Code Online (Sandbox Code Playgroud)
如果您通常了解对象引用的工作原理,则很容易理解对象数组如何受到克隆和修改的影响.为了进一步了解参考文献和原语,我建议阅读这篇优秀的文章.