java中的hashcode和equals有什么区别
java中的hashcode和equals有什么区别?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
大连网站建设公司创新互联公司,大连网站设计制作,有大型网站制作公司丰富经验。已为大连千余家提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的大连做网站的公司定做!
hashcode:对象的初始地址的整数表示
3、Integer类,返回的哈希码就是Integer对象里所包含的那个整数的数值,例如Integer i1=new Integer(100),i1.hashCode的值就是100 。由此可见,2个一样大小的Integer对象,返回的哈希码也一样。
hashCode是为了提高在散列结构存储中查找的效率,在线性表中没有作用。
equals被用来检测两个对象是否相等,即两个对象的内容是否相等。
区别:
一般一个类的对象如果会存储在HashTable,HashSet,HashMap等散列存储结构中,那么重写equals后最好也重写hashCode,否则会导致存储数据的不唯一性(存储了两个equals相等的数据)。而如果确定不会存储在这些散列结构中,则可以不重写hashCode。
若两个对象equals返回true,则hashCode有必要也返回相同的int数。
若两个对象equals返回false,则hashCode不一定返回不同的int数,但为不相等的对象生成不同hashCode值可以提高哈希表的性能。
若两个对象hashCode返回相同int数,则equals不一定返回true。
若两个对象hashCode返回不同int数,则equals一定返回false。
同一对象在执行期间若已经存储在集合中,则不能修改影响hashCode值的相关信息,否则会导致内存泄露问题。
一般来说涉及到对象之间的比较大小就需要重写equals方法。
关于java中的hashcode和equals有什么区别问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。
名称栏目:java中的hashcode和equals有什么区别
标题来源:http://scyanting.com/article/jsegss.html