下面的代码不是像Javadoc提到的关于clone()方法那样创建浅拷贝的
// Do the same with object arrays
obj O[] = new obj[5];
obj Oc[] = O.clone();
System.out.println("Identity hashcode of obj arrays");
System.out.println(System.identityHashCode(O));
System.out.println(System.identityHashCode(Oc));
// check objects equalness
if(O.equals(Oc)){
System.out.println("Objects are equal!");
}输出:
Identity hashcode of obj arrays
2018699554
1311053135我哪里出问题了?
发布于 2015-10-29 09:39:31
是的,输出和预期的一样。两个数组的标识哈希码将是不同的,因为它们是顶层的两个不同的对象(由两个不同的引用所指向)。因此,if..条件也会失败。
浅拷贝的意思是:容器(数组、列表等)将被创建,但是它们中的ht元素/引用不会是新创建的,相反,将使用/复制原始引用。
发布于 2015-10-29 09:39:46
您似乎期望克隆的数组与原始数组相等,这是通过调用O.equals(Oc)确定的。
但是由于数组不覆盖Object.equals (JLS10.7),所以这个调用只测试O == Oc。因此,即使O.equals(Oc)返回false,这并不意味着Oc不是O的浅拷贝。
要测试数组元素的相等性,可以使用Arrays.equals(O, Oc)
发布于 2015-10-29 09:45:16
克隆方法将返回对新数组的引用,该数组引用与源数组相同的对象。
两个数组的HashCode不一样,这两个是两个不同的对象。
https://stackoverflow.com/questions/33410209
复制相似问题