hashcode方法返回该对象的哈希码值,其值一般是该对象在内存上的地址。
hashCode的常规协定是:
在Java应用程序执行期间,在同一对象上多次调用hashCode方法时,必须一致地返回相同的整数,前提是对象的equals比较中所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
如果根据equals(Object)方法,两个对象是相等的,那么每个对象调用hashCode方法都必须生成相同的整数结果。
以下情况不是必需的:
如果根据equals(java.lang.Object)方法,两个对象不相等,那么在两个对象中的任一对象上调用hashCode方法必定会生成不同的整数结果。实际上,由Object类定义的hashCode方法确实会针对不同的对象返回不同的整数。(这一般是通过将该对象的内部地址转换成一个整数来实现的)
当equals方法被重写时,通常有必要重写hashCode方法,以维护hashCode方法的常规协定,该协定声明相等对象必须具有相等的哈希码。
几个关键点:
1、hashCode的存在主要是用于查找的快捷性,如Hashtable,HashMap等 ,hashCode是用来在散列存储结构中确定对象的存储地址的;
2、如果两个对象相同,就是适用于equals(Java.lang.Object)方法,那么这两个对象的hashCode一定要相同;
3、如果对象的equals方法被重写,那么hashCode也尽量重写,否则就会违反上面提到的第2点;
4、两个对象的hashCode相同,并不一定表