HashSet如何判断插入元素重复的研究

上次面试时被面试官被到这个问题,当时没有答对,后来自己研究了下,到今天总算是弄明白了。
先定义一个类,当然既然要放入到hashSet中当然要重写hashcode()方法和equal()方法。

package com.map.test;

/**
 * Created by 74039 on 2017-02-26.
 */
public class Cat {

    private int a;
    private String name;

    public Cat(int a, String name) {
        this.a = a;
        this.name = name;
    }
    public Cat() {
    }

    @Override
    public boolean equals(Object o) {
        System.out.println("我是equals方法");
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;

        Cat cat = (Cat) o;

        if (a != cat.a) return false;
        if (!name.equals(cat.name)) return false;

        return true;
    }

    @Override
    public int hashCode() {
        System.out.println("我是hashcode方法");
        int result = a;
        result = 31 * result;// + name.hashCode();*/
        return result;
    }

    public int getA() {
        return a;
    }

    public void setA(int a) {
        this.a = a;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

再来写一个测试类,如下

package com.map.test;

import java.util.HashSet;
import java.util.Set;

/**
* Created by 74039 on 2017-02-26.
*/
public class App1 {
public static void main(String[] args) {
Set catSet=new HashSet();
//catSet.add()
Cat cat=new Cat(1,”hello”);
Cat cat2=new Cat(3,”hello”);
Cat cat3=new Cat(1,”hello3”);
Cat cat4=new Cat(3,”hello4”) ;
catSet.add(cat);
System.out.println(“===========”);
catSet.add(cat2);
System.out.println(“===========”);
catSet.add(cat3);
System.out.println(“===========”);
catSet.add(cat4);
System.out.println(catSet.size());
}
}

直接先看程序的运行结果,然后在解析分析:

我是hashcode方法
===========
我是hashcode方法
===========
我是hashcode方法
我是equals方法
===========
我是hashcode方法
我是equals方法
4

控制台打印输出如上信息,可以看到每次添加元素都会调用hashcode方法,而只有当hashcode一样时才会调用equals方法。
说明,在插入元素时会首先调用hashcode方法来判断有无重复,如果没有直接插入,如果有则去比较hashcode重复的对象的equals方法,看equals是否重复,如果equals一样,不会插入,如果equals不一样,则插入。
以上就是我的理解。期待同各位高手经常交流。QQ:740393778

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值