码迷,mamicode.com
首页 > 其他好文 > 详细

composite key 与hashcode,equals

时间:2018-04-28 17:59:13      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:修改   应用程序   tps   obj   返回   pos   查找   nbsp   com   

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

标签:修改   应用程序   tps   obj   返回   pos   查找   nbsp   com   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!