揭秘 HashSet:基于 HashMap 的不重复魔法

23年毕业半年被裁后,一个月斩获大厂offer,“跟着周哥走,offer手里有”。文中有周哥50+场面试总结出的必会面试题。

本期说一下HashSet的相关面试题。

注:接下来的内容来自本人整理的面试秘籍。
点击此处,无套路免费获取面试秘籍

说一下 HashSet 的实现原理?

HashSet 是基于 HashMap 实现的,HashSet的值存放于HashMap的key上。使用HashMap实现HashSet时,HashMap的value统一为present=new Objec()。因此 HashSet 的实现比较简单,相关 HashSet 的操作,基本上都是直接调用底层HashMap 的相关方法来完成。我们知道HashMap的key不允许重复,因此HashSet存储的值是不允许重复的值。

HashSet如何保证元素不重复?

HashSet底层采用HashMap保存元素,HashSet中保存的元素就是HashMap中的Key,而HashMap中的Key是不重复的,所以HashSet中的元素不会重复。(Vuale存储的都的Object类型的Present)


更深层次原因是:
HashSet在添加元素时,会调用,HashMap中的put方法。
在put方法中,首先会计算key的hash值,将(数组长度-1)与hash值进行&操作,得到插入哈希表的位置。

如果该位置已经存在元素,那么会进行如下判断(体现去重操作)

  • 若两元素key的hash值不同,说明不重复,则存入,存入方式为链表或红黑树
  • 若key的hash值相同,且equals相同,说明重复,不存在
  • 若key的hash值相同,但equals不同,不重复,则存入,存入方式为链表或红黑树

**注:**其实,直接用equals就可以判断出来,之所以,先用hash判断,是避免多次调用equals以增加开销。

工作日每天更新,周末随缘更新。

请关注我,以便及时获取最新内容哦!

个人专栏持续更新
Java 基础秘籍:打破新手困境,迈向高手之路

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值