在java中,覆盖Object类的equals()方法的同时为什必须覆盖hashCode()方法?
在java中,覆盖Object类的equals()方法的同时为什必须覆盖hashCode()方法?...
在java中,覆盖Object类的equals()方法的同时为什必须覆盖hashCode()方法?
展开
展开全部
因为java的collection很多都需要hashCode(),例如HashTable
比如说你往里面存了一个值,你在取这个值的时候,java实际上通过hashCode()来找那个值,因为这样通常比较快。如果你覆盖了equals()方法,意味着原来不相等的两个对象现在可能变得相等,但hashCode()的值却不相等,这样你使用HashTable就会出现存进去的东西找不到。
不要忽略这个问题,因为HashTable等等类用的非常多,很可能就在一个你不知道的地方间接地用到了。java类的一个原则就是:你定义的任何类,都要考虑覆盖equals和hashCode方法。否则你的类就不能给其他人或其他地方用。
比如说你往里面存了一个值,你在取这个值的时候,java实际上通过hashCode()来找那个值,因为这样通常比较快。如果你覆盖了equals()方法,意味着原来不相等的两个对象现在可能变得相等,但hashCode()的值却不相等,这样你使用HashTable就会出现存进去的东西找不到。
不要忽略这个问题,因为HashTable等等类用的非常多,很可能就在一个你不知道的地方间接地用到了。java类的一个原则就是:你定义的任何类,都要考虑覆盖equals和hashCode方法。否则你的类就不能给其他人或其他地方用。
展开全部
覆盖hashcode类主要用要set集合里面..
在set集合中为了确保集合元素的唯一性,集合中没有重复的元素,插入的时候会用equals()方法按照内存地址来比较对象是否相等,当你的equals()方法没有被覆盖时,比较得出两个object地址为true,其哈希码一定也相同,
当你覆盖了equals()方法的,可能你比较出来的equals()结果是true,但两个object的在内存中存放地址不同,哈希码可能会不同,这就的话hashset这个就无法正常运行,所以为了保证HashSet正常工作,这时要同时覆盖HashCode()方法....
孙卫琴的精通 < <hibernate> > 里讲了的
在Object类中定义了hashCode()和equals()方法,Object类的equals()方法按照内存地址比较对象是否相等,因此如果 object1.equals(object2)为true,表明object1变量和object2变量实际上引用同一个对象,那么object1和 object2的哈希码肯定也相同,也就是说object1.hashCode()==object2.hashCode()
如果用户定义的类覆盖了Object类的equals()方法,但是没有覆盖Object类的hashCode()方法,就会导致当 object1.equals(object2)为true 时,而 object1 和 object2的哈希码不一定一样。
所以如果覆盖了equals()方法,也应该覆盖hashCode()方法,并且保证2个相等的object对象的哈希码也一样
代码:
ObjectChild覆盖Object类的equals()方法
public boolean equals(Object o){
if(this==0) return true;
if(! (o instanceof ObjectChild)) return false;
final ObjectChild other = (ObjectChild) o ;
if(this.name.equals(other.getName()) && this.age == other.getAge())
//这里假定的 ObjectChild 是一个JavaBean 对象,含有 name 和 age 2个属性,如果name和age相同,则看为同一个对象
return true;
else
return false;
}
ObjectChild覆盖Object类的hashCode()方法
//返回自定义方法计算出的hashCode值,使得拥有相同属性的对象拥有相同的hashCode;
public int hashCode(){
int result;
result = (name==null?0:name.hashCode());
result = 29*result + (age==null?0:age.hashCode());
return result;
}
在set集合中为了确保集合元素的唯一性,集合中没有重复的元素,插入的时候会用equals()方法按照内存地址来比较对象是否相等,当你的equals()方法没有被覆盖时,比较得出两个object地址为true,其哈希码一定也相同,
当你覆盖了equals()方法的,可能你比较出来的equals()结果是true,但两个object的在内存中存放地址不同,哈希码可能会不同,这就的话hashset这个就无法正常运行,所以为了保证HashSet正常工作,这时要同时覆盖HashCode()方法....
孙卫琴的精通 < <hibernate> > 里讲了的
在Object类中定义了hashCode()和equals()方法,Object类的equals()方法按照内存地址比较对象是否相等,因此如果 object1.equals(object2)为true,表明object1变量和object2变量实际上引用同一个对象,那么object1和 object2的哈希码肯定也相同,也就是说object1.hashCode()==object2.hashCode()
如果用户定义的类覆盖了Object类的equals()方法,但是没有覆盖Object类的hashCode()方法,就会导致当 object1.equals(object2)为true 时,而 object1 和 object2的哈希码不一定一样。
所以如果覆盖了equals()方法,也应该覆盖hashCode()方法,并且保证2个相等的object对象的哈希码也一样
代码:
ObjectChild覆盖Object类的equals()方法
public boolean equals(Object o){
if(this==0) return true;
if(! (o instanceof ObjectChild)) return false;
final ObjectChild other = (ObjectChild) o ;
if(this.name.equals(other.getName()) && this.age == other.getAge())
//这里假定的 ObjectChild 是一个JavaBean 对象,含有 name 和 age 2个属性,如果name和age相同,则看为同一个对象
return true;
else
return false;
}
ObjectChild覆盖Object类的hashCode()方法
//返回自定义方法计算出的hashCode值,使得拥有相同属性的对象拥有相同的hashCode;
public int hashCode(){
int result;
result = (name==null?0:name.hashCode());
result = 29*result + (age==null?0:age.hashCode());
return result;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
没有这个必要,覆盖equals是为了判断两个类相等问题,和Hash没啥关系,只有用到HashSet等用到哈西码的地方才需要覆盖HashCode方法因为他要作出是否相同的判断,当然这时也必须覆盖equals方法,因为这个判断需要用到这两个方法,可能你在学习的时候有混淆
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在同一个抽象类中 必须实现一次
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询