[英]What JVM checks in Java object equality (==)?
JVM 在对象相等性 ( ==
) 中检查什么? 是两个对象的hashCode
还是别的?
==
运算符仅检查引用相等性。 它不调用对象上的任何方法...它只是检查涉及的两个引用是否相等,即它们引用同一个对象。
在简单的情况下,我相信这只是按位方式比较引用的问题——检查它们是否由相同的字节组成。 对于更复杂的环境(例如“压缩的 oops” ),可能会涉及更多的工作,以便比较不同的表示。 但内部引用实际上是某种指针,只是比较两个指针的问题。
== 用于比较对象引用。 它只是检查两个对象是否指向同一个引用。
相等运算符 ( ==
) 测试引用相等性而不是hashCode
public static void main(String[] args) {
MyClass obj1=new MyClass();
MyClass obj2=new MyClass(); //obj1 and obj2 refers two different location
System.out.println("obj1= "+obj1+"\tobj2="+obj2);
if(obj1==obj2){ // so return false.
System.out.println("obj1==obj2");
}else{
System.out.println("obj1!=obj2");
}
System.out.println(obj1.hashCode()+"\t"+obj2.hashCode());
}
class MyClass{}
输出:
obj1= com.think.test.MyClass@1e9cb75 obj2=com.think.test.MyClass@2c84d9
obj1!=obj2
hashCode
obj1=32099189 obj2=2917593
编辑
class EqualityTest {
@Override
public int hashCode(){
return 1;
}
public static void main(String... arg){
EqualityTest t1 = new EqualityTest();
EqualityTest t2 =t1; // t2 referring to t1.
System.out.println(t1);
System.out.println(t2);
System.out.println(t1.hashCode());
System.out.println(t2.hashCode());
System.out.println(t1==t2); // so it return true.
}
}
输出:
com.think.test.Test9@1
com.think.test.Test9@1
1
1
true
很容易看出 JVM 如何在字节码级别处理==
。
例如
public boolean compare(Object o1, Object o2)
{
return o1 == o2;
}
编译为以下字节码指令(使用javap -c
生成):
public boolean compare(java.lang.Object, java.lang.Object);
Code:
0: aload_1
1: aload_2
2: if_acmpne 7
5: iconst_1
6: ireturn
7: iconst_0
8: ireturn
aload1
和aload2
在堆栈上加载 o1 和 o2 的引用。 ==
操作由if_acmpne
执行。
if_acmpne 从堆栈中弹出顶部的两个对象引用并比较它们。 如果两个对象引用不相等(即,如果它们引用不同的对象) ,则执行分支到...。如果对象引用引用相同的对象,则执行在下一条指令处继续。
当然,这并没有告诉您 JVM 解释器如何实现对象引用,或者像 Hotspot 这样的本机编译器的字节码如何实现它,但它是探索该主题的良好开端。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.