以下代码未创建浅层副本,因为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
我哪里错了?
答案 0 :(得分:3)
是的,输出符合预期。两个数组的标识哈希码将是不同的,因为它们是顶层的2个不同的对象(由2个不同的引用指向)。因此,if..
条件也会失败。
浅层拷贝意味着: 将创建容器(数组,列表等),但不会新创建其中的元素/引用,而是将使用/复制原始参考文献。
答案 1 :(得分:1)
您似乎期望克隆的数组将等于原始数组,这可以通过调用O.equals(Oc)
来确定。
但由于数组不会覆盖Object.equals
(JLS 10.7),因此此调用仅测试O == Oc
。
因此,即使O.equals(Oc)
确实返回false,也不意味着Oc
不是O
的浅层副本。
要测试数组元素的相等性,可以使用Arrays.equals(O, Oc)
答案 2 :(得分:0)
clone方法将返回对新数组的引用 引用与源数组相同的对象
两个数组的HashCode不会相同,这两个是两个不同的对象。