我们观察如下代码
package test;
import java.util.HashSet;
public class Test {
public static void main(String[] args) {
Student stu1=new Student();
System.out.println(stu1.hashCode());
System.out.println(stu1);
System.out.println(Integer.toHexString(stu1.hashCode()));
}
}
执行结果
5433634
test.Student@52e922
52e922
我们可以看到,hashCode执行结果出来的是一串数字,具体不知道用来干什么的。我们的第二个输出语句打印了对象的地址,神奇的事情来了,第三个输出语句方法为将十六进制转换成二进制,我们发现将hashCode打印出来的数字转换成二进制后刚好为对象的地址。
我们不难的出结论,hashCode方法与地址息息相关,每一个对象调用hashCode方法所打印的值都是相同的。
例外:
package test;
import java.util.HashSet;
public class Test {
public static void main(String[] args) {
String name1="Tom";
String name2=new String("Tom");
System.out.println(name1.hashCode());
System.out.println(name2.hashCode());
System.out.println(name1==name2);
}
}
执行结果:
84274
84274
false
我们发现name1和name2的地址是不同的这个通过“==”就可以判定,但是为什么他们两个对象调用hashCode方法输出的值是同一个值呢?
因为String中重写了hashCode方法,至于如何重写的我们不需要知道。只需要知道因为重写,即使是两个地址不同的对象,如果字符串内容相同,那么调用hashCode方法时仍然会输出相同的值!