为什么重写equals时必须重写hashCode方法

时间:2017.10.18 发布人:**mrwgp06

为什么重写equals时必须重写hashCode方法

已解决问题

谷歌**mrwgp06用户在2017.10.18提交了关于“泰山为什么重写equals时必须重写hashCode方法”的提问,欢迎大家涌跃发表自己的观点。目前共有1个回答,最后更新于2024-08-31T14:51:23。希望大家能够帮助她。

详细问题描述及疑问:期待您的答案,没有什么华丽的语言,但是我对你的感谢不会减少 !

希望以下的回答,能够帮助你。

第1个回答

用户名:sunguan199  

如果你重载了equals,比如说是基于对象的内容实现来自的,而保留has存思写乱社源裂怀hCode的实现不变,那么很可能某两个对象明明是“相等”,而hashCode却不一样。
这样,当你用其中的一个作为键问答保存到hashMap、hasoTable或hashSet中,再以“相等的”找另一个作为键值去查找他们的时候,则根本找不到。
使用h**ashMap,如果key是自定义的类,就必须重写hashcode()和除识包商备浓equals()。
而对于每一个对象,通过其hashCode()方法可为其生成一个整形值(散列码青够调),该整型值被处理后,将会作为数组下标,存放该对象所对应的Entry(存放该对象及其对应值)。equals()方法则是在h**ash林氢还Map中插入值或查询江游观间奏坐元沙时会使用到。当h**ashMap中插入值或查询衷应的散列码与数组中的散列码相等时,则会通过equals方法比较key值是否相等,所以想以自建对象作为h**ashMap的key,必须重写该对象继承object的态胡头除注终hashCode和equals方法。2.本来不就有hashcode()和equals()了么?干嘛要重写,直接用原来的不行书浓盾群升科殖析女家盟么?h**ashMap中,如果要比较key是否相等,要同时使用这两个函数!因为自定义的类的hashcode()方法继承于Object类,其h通志跑料乡钟神八ashcode码为默认的内存地址,这样即便有相同含义的景体火良两个对象,比较也是不司菜大委块定独黑相等的,例如,生成了两个“羊”对象,正常理解这两个对象应该是相等的,但如晶生块挥院质果你不重写hashcode()方法的三它种斯话,比较是不相等的!
h**ashMap中的比较key是这样的,先求出key的hashco月航de(),比较其值是否相等,若相等再比较equals(),若相等则认为他们是相等的。若equals()不相等则认为他们不相等。如果只重写hashcode()不重写equals()方法,当如武动食措方争项茶觉比较equals()时只是看他们是否为同一对象(即进行内存地址的比较),所以必定要两个方法一起重写。h**ashMap用来判断key是否相等的方法,其实是调用了h**a额shSet判断加入元素是否相等。
引用别人说的一段话哈~
一般来说,如果你要把一个类的对象放入容器中,那么通常要为其重写equals()方法,让他们比较地址著不是内容值。特别地,如果要把你的类的对象放入散列中,那么还要重写hashCode()方法;要放到有序容器中,还要重写compareTo()方法。
equals()相等的两个对象,hashcode()一定相等;
equals()不相等的两个对象,却并不能明他们的hashcode()不相等。换句话说,equals()方法不相等的两个对象,hashcode()有可能相等。(我的理解是由于哈希码在生成的时候**生冲突造成的)。
反过来:hashcode()不等,一定能推出equals()也不等;hashcode()相等,equals()可能相等,也可能不等
我的理解哈,