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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 戎石锁 中级黑马   /  2012-8-10 13:31  /  1333 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

(1)通常来说,一个类的两个实例对象用equals方法比较的结果相等的时候,他们的哈希码也必须相等,但反之则不成立,即equals方法比较结果不相等的对象可以有相同的哈希码,或者说哈希码相同的两个对象的equals方法比较的结果可以不等,例如,字符串BB和Aa的equals方法比较的结果肯定不相等,但是他们的hashCode方法返回值相等。
(2)当一个对象被存储到HashSet集合中以后,就不能修改这个对象中的某些参与计算哈希码的字段了,否则,对象修改以后的哈希码与最初存储金集合的哈希码就不同了,在这种情况下,即使在contains方法使用该对象的当前引用作为的参数去HashSet集合中检索对象,也将返回找不到对象的结果,这也会导致无法从Hash集合中单独的删除当前的对象,从而造成内存泄漏。

都有点小疑惑,希望大家能解惑···(最好有文字有代码,谢谢)

点评

提的问题很有质量,希望一直保持这个状态!  发表于 2012-8-10 14:36

评分

参与人数 1技术分 +1 收起 理由
张立江 + 1 很给力!

查看全部评分

1 个回复

倒序浏览
你的第一个问题
HashSet的工作原理:每次存储对象的时候,调用对象的hashCode,计算一个哈希值,在集合中找是否包含哈希值相同的元素,如果没有直接将元素存入,如果有哈希值相同的元素,逐个使用equals()方法,,比较结果全为false就存入,如果比较结果为true则不存。而为了提高效率,通常会自己写一个hashCode方法,让属性相同的元素哈希值肯定相同,不同的话就去比较equals。例如:定义一个学生类,属性有名字,年龄。然后你自己定义一个hashCode方法:public int hashCode() {
                                                                                return name.length() + age;
                                                        }
hashCode和equals这两个缺一不可,所以以后要将自定义类对象存入HashSet去重复就需要:
类中必须重写hashCode()和equals()方法
equals()方法中比较所有属性
hashCode()方法要保证属性相同的对象返回值相同,属性不同的对象尽量不同

评分

参与人数 1技术分 +1 收起 理由
张立江 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马