Hashcode() 和 equals() 重写的原因

学到hashset时遇到了这个问题

场景需求:因为要把属性一样的对象去重只存一次

解决方法:重写了hashcode和equals

问题来了,为什么?下面是自己的理解

提前明白一个事儿:

两个对象相等,hashcode一定相等


    两个对象不等,hashcode不一定不等
    hashcode相等,两个对象不一定相等


hashcode不等,两个对象一定不等

重点在中间两句。

原始的hashcode是object自带的,返回的hashcode就是对象的地址值。

现在的需求要求我们,属性相同的对象就要返回相同的hashcode

so we overwrite了 hashcode()

@Override
    public int hashCode() {
        return stuName.hashCode()+new Integer(stuAge).hashCode()+stuGender.hashCode();
    }

先来一个弱筛选,大概率如果hashcode相同他们的各个属性就相同了。但是也有例外

比如:一个对象a属性1比对象b属性1的hashcode少了1,同时呢,对象a的属性2比对象b的属性2多了1。(纯个人理解猜测)一来一回计算的hashcode值是一样的,但是对象ab的属性是不一样的,那么equals方法的重写就派上用场了。印证了上述 hashcode相等,两个对象不一定相等。

重写equals方法目的就是简单粗暴地判断两个对象各个属性是否一样

 @Override
    public boolean equals(Object obj) {
        boolean flag = false;
        if(this == obj){//一个对象赋值三次,地址一样直接相同
            flag = true;
        }else{
            if(obj instanceof Student){//要比较的对象是否是student类或者他的子类,不是不进入if直接return
                Student stu = (Student)obj;
                if(this.getStuName().equals(stu.getStuName())
                        &&this.stuAge==stu.getStuAge()
                        &&this.getStuGender().equals(stu.getStuGender())){
                    flag = true;
                }
            }
        }
        return flag;
    }

至此完成。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Java中,hashcodeequals方法是用于比较对象的重要方法。当我们需要比较两个对象是否相等时,就需要重写这两个方法。 hashcode方法是用于获取对象的哈希码,它返回一个int类型的值。在重写hashcode方法时,我们需要保证相等的对象返回相同的哈希码,这样才能保证在使用哈希表等数据结构时,对象能够正确地被存储和查找。 equals方法是用于比较两个对象是否相等,它返回一个boolean类型的值。在重写equals方法时,我们需要保证相等的对象返回true,不相等的对象返回false。通常情况下,我们需要比较对象的属性值是否相等来判断两个对象是否相等。 需要注意的是,当我们重写equals方法时,也需要同时重写hashcode方法,否则在使用哈希表等数据结构时,可能会出现错误。 ### 回答2: hashcodeequals都属于Object类中的方法,而在Java中,许多数据结构都需要根据对象的hashcodeequals方法来判断某个对象在数据结构中的位置和是否相等。因此,我们通常需要重写这两个方法来满足自己的需求。 hashcode方法是返回某个对象的哈希码,它的作用是在HashMap、HashSet等数据结构中对对象进行分类。如果两个对象使用equals方法比较返回true,那么它们的hashcode方法必须返回相同的值,否则可能会造成数据结构失效导致数据无法取出。如果两个对象的hashcode值相等,但是使用equals方法比较返回false,这种情况称为哈希冲突。我们可以通过提高哈希冲突的概率来提高数据访问效率,例如优化哈希函数或者增大哈希表的容量。 equals方法是用来比较两个对象是否相等,我们可以根据对象中的属性来自定义相等的规则。常见的重写方式是比较对象中每个属性的值是否相等。需要注意的是,我们需要保证equals方法满足自反性、对称性、传递性和一致性等特征,否则可能导致数据结构错误或程序异常。 在Java中,通常当我们自定义一个类时,需要重写这两个方法以保证程序的正确性和程序运行效率。重写的方法要根据实际情况来选择,我们可以根据每个对象的属性来计算hashcode,也可以使用一些第三方框架来自动实现equalshashcode方法,例如lombok、Apache Commons等。无论选择哪种方式,我们都要保证程序正确性和运行效率的平衡。 ### 回答3: Java中的hashcodeequals方法是常用的对象方法,它们的作用是对对象进行操作和比较。在使用Java集合类时,如HashMap、HashSet、HashTable等都会用到hashcodeequals方法。 hashcode方法是Object类中定义的方法,它返回对象的哈希码值。哈希码值是一个int类型的整数,它通过将该对象的内部地址转换成一个整数来计算。如果需要使用自定义的容器或自定义的集合类时,需要重写hashcode方法以提高容器性能。 equals方法也是Object类中定义的方法,它用于比较两个对象是否相等。当需要判断两个对象是否相等时,就需要重写equals方法。通常情况下,equals方法比较的是对象的属性值,所以在实现equals方法时需要考虑对象的属性。 在重写equals方法时,需要注意以下几点: 1. 重写equals方法时,需要保证它遵循自反性、对称性、传递性和一致性这四个基本原则。 2. 对象相等的条件是对象的属性值相等,而不是内存地址相等。 3. 在比较对象属性时,需要避免空指针异常。 4. 当对象中包含集合类型的属性时,在比较集合类型属性时需要递归比较每个元素。 当对hashcodeequals方法进行重写时,需要同时重写。如果两个对象的equals方法返回true,那么它们的hashcode也应该相同。同时,如果两个对象的hashcode相同,那么它们不一定相等,需要通过equals方法再次比较。 总之,对hashcodeequals方法的重写可以提高Java容器的性能,也可以确保对象比较的正确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值