composite key 与hashcode,equals

1、hashCode的存在主要是用于查找的快捷性,如Hashtable,HashMap等,hashCode是用来在散列存储结构中确定对象的存储地址的;在 Java 应用程序执行期间,在对同一对      象多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是将对象进行 equals 比较时所用的信息没有被修改。

2、如果两个对象相同,就是适用于equals(java.lang.Object) 方法,那么这两个对象的hashCode一定要相同;equals(Object) 方法是指Object类中未被子类重写过的equals方法

      如果两个hashCode()返回的结果相等,则两个对象的equals方法不一定相等。

     如果根据equals(java.lang.Object)方法,两个对象不相等,那么对这两个对象中的任一对象上调用 hashCode 方法不一定生成不同的整数结果。但是,程序员应该意识到,为不相等的对象生成不同整数结果可以提高哈希表的性能。

3、如果对象的equals方法被重写,那么对象的hashCode也尽量重写,并且产生hashCode使用的对象,一定要和equals方法中使用的一致,否则就会违反上面提到的第2点;

4、两个对象的hashCode相同,并不一定表示两个对象就相同,也就是不一定适用于equals(java.lang.Object) 方法,只能够说明这两个对象在散列存储结构中,如Hashtable,他们“存放在同一个篮子里”。

参考:https://www.sogou.com/link?url=DOb0bgH2eKh1ibpaMGjuy1Vv78Wo0PVv4fZWZOQHECGueKW9M67CaVLpMY1k7wxTVhRrW5zu__s.

 

猜你喜欢

转载自www.cnblogs.com/12qw/p/8968844.html