只有类的实例对象要被采用哈希算法进行存储和检索时,这个类才需要按要求覆盖
hashcode()。即使程序可能暂时不会用到当前类的hashcode()方法,但是为它提供一个
hashcode()方法也没什么不好,没准以后什么时候又用到这个方法了,所以,通常要求
hashcode()方法和equals方法一并被同时覆盖。
要点:(1)通常来说,一个类的两个实例对象用equals()方法比较的结果相等时,
它们的哈希码也必须相等,但反之则不成立,即equals方法比较结果不相等的
对象可以有相同的哈希码。或者说哈希码相同的两个对象的equals方法比较的
结果可以不等,例如,字符串"BB"和"Aa"的equals方法比较结果肯定不相等,但
它们的hashcode方法返回值却相等。
(2)当一个对象被存储进HashSet集合中以后,就不能修改这个对象中的那些参与
计算哈希值的字段了,否则,对象修改后的哈希值与最初存储进HashSet集合中时
的哈希值就不同了,在这种情况下,即使在contains方法使用该对象的当前引用
作为的参数去HashSet集合中检索对象,也将返回找不到对象的结果,这也会导致
无法从HashSet集合中单独删除当前对象,从而造成内存泄露。 |