A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© pupilguan 中级黑马   /  2015-1-10 00:37  /  1327 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

Hash表的hashCode和equals方法具体要什么时候复写呢?一直搞不懂!{:2_43:}

3 个回复

倒序浏览
当一个类的对象,需要有自己的方式去判断是否相等时,这时候就需要去重新equals方法了。一般来说,重新equals方法时,必须重新hashcode方法,因为同一对象的hashcode值是一样的,不然当你在使用底层是hash结构的集合存取这些对象时就会出问题了!
回复 使用道具 举报
jojo 发表于 2015-1-10 00:46
当一个类的对象,需要有自己的方式去判断是否相等时,这时候就需要去重新equals方法了。一般来说,重新equa ...

说得好,就是数据结构中的散列表存储问题
散列表的知识:
散列表(哈希表)的百度百科
对就到Java中来,一个对象的值是什么没有办法说,所以我们用equals方法,返回true的就认为两个对象的值相同,反之则不同,再所以两个值相同的对象计算的散列地址也应该相同,而散列地址对应在Java中的就是HashCode。总之要重写就都重写,重写的原则就是两个对象equals则HashCode就要相同。(当然不要将所有HashCode返回一个相同的值,这样会影响运行的效率,原因见百度百科)
回复 使用道具 举报
我明明用了超链接。。。。
散列表的知识:散列表(哈希表)的百度百科
http://baike.baidu.com/link?url=jz8SKQA6LWSkcBHkLeMV6WQ9b6wCbx1L87luWyAf_rAxmffyj-
hqzukPBoO1_0IK8ckqQ-yf6DEmSlyaXZOmQq
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马