首页 > 其他 > 详细

composite key 与hashcode,equals

时间:2018-04-28 17:26:35      阅读:198      评论:0      收藏:0      [点我收藏+]

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.

 

 

composite key 与hashcode,equals

原文:https://www.cnblogs.com/12qw/p/8968844.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!