Java Collections Framework学习笔记之HashSet

HashSet其实是借助HashMap实现的

    public HashSet() {
        map = new HashMap<>();
    }

所以HashSet和HashMap肯定有很多关联的地方,不同之处就在于HashSet是只能存储相同类型的对象,而HashMap可以存储键值对。

HashMap是不保证顺序的,而HashSet内部是用HashMap来存储,所以也不保证顺序,这两个容器都不能存储相同的元素(可以想象一对双胞胎,如果没有出生先后顺序,我们是无法分辨他们的)

同时,HashSet其实是利用HashMap中Key的唯一性,来保证HashSet中不出现重复值,它元素实际上是作为HashMap中的Key存放在HashMap中的

    // HashSet中add方法的实现
    public boolean add(E e) {
        // 将新值作为HashMap的key存入,这里的PRESENT是一个与新值关联的虚拟值
        return map.put(e, PRESENT)==null;
    }

而HashMap中的put时需要使用到key.hashCode()和key.equals()来判断key的唯一性,详见 Java Collections Framework学习笔记之HashMap

所以,敲黑板了!

被放到HashSet中的元素对应的类,必须是覆写过hashCode()和equals()方法的!这样才能保证HashSet能正常使用(即存放的对象没有重复)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值