黑马程序员--07.集合框架--02. 重写HashCode的内存变化过程以及两种重写hashCode方式的比较【个人总结】

本文介绍了在Java中重写hashCode方法的必要性和具体过程,特别是针对HashSet避免重复添加对象的情况。通过实例展示了两种重写方式的比较,强调了根据equals方法中比较的属性进行线性组合来生成hashCode值的重要性,以减少不必要的equals比较和提高性能。
摘要由CSDN通过智能技术生成

重写HashCode

      重写HashCode的内存变化过程 两种重写方式的比较

----------- android培训java培训、java学习型技术博客、期待与您交流! ------------

(1). 主要代码

class Person{
    private String name;
    private int age;
   
    public static void sop(Object o){
        System.out.println(o);
    }
 
    public Person(String name, int age){
        this.name =name;
        this.age =age;
    }
 
    public void setName(String name){
        this.name =name;
    }
   
    public String getName(){
        return this.name;
    }
 
    public void setAge(int age){
        this.age =age;
    }
 
    public int getAge(){
        return this.age;
    }
 
    public String toString(){
        return this.name+"::"+this.age;
    }
 
    //equals已经重写
public boolean equals(Object obj){
if(!(obj instanceof Person)){
            return false;
        }
   
        Person p =(Person)obj;
 
        //用来查看equals方法是否被调用
        sop(this.name +".......equals......."+ p.name);
        //认为名字相同并且年龄一样大的两个对象是一个
return this.name.equals(p.name) && this.age == p.age;
}
}

(2). 将hashCode()重写成相同的值-----解决HashSet中重复添加

[1]. 问题:内容相同但是地址不同自定义对象如何避免重复的内容添加到HashSet中?

【解决办法】必须重写hashCodeequal

  • 10
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值