HashSet与LinkedHashSet源码分析

本文深入探讨了HashSet和LinkedHashSet的内部实现原理,揭示了它们如何利用HashMap和LinkedHashMap进行高效的数据存储与检索,以及其背后的独特设计哲学。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

刚看过HashMap的源码,再看HashSet的源码,发现HashSet简直太不要脸了,底层就封装了一个HashMap,然后各种方法就使用HashMap的方法,就连遍历都是HashMap实现的。还要挂着set的名。也是醉了。LinkedHashSet也是一样。封装的是LinkedHashMap。
HashSet只使用了HashMap的Key,HashMap的所有的Value统统填充一个常量Object对象。
所以HashMap的Key拥有的特性,HashSet都具有,比如说,HashMap是无序的,所以HashSet就是无序的,至于HashSet不重复,因为HashMap遇见Key相同的情况就会更新Value值,而不会增加Key值,所以HashSet也不增加。
在这里插入图片描述
常量PRESENT,填充HashMap的Value用的。
构造一个HashSet就默认构造一个HashMap。
在这里插入图片描述
遍历用的map实现的方法遍历的,长度返回的是map的长度,空不空判断map空不空。
在这里插入图片描述
添加就是添加Key跟常量。
LinkedHashSet源码里都是用的父类方法,直接父类是HashSet,HashSet里有一个专门构造LinkedHashSet的方法,
在这里插入图片描述
只有这一个构造是三个参数的,而且无论LinkedHashSet的构造有几个参数,最终调的都是HashSet的这个方法。因此LinkedHashSet对LinkedHashMap的借用就跟HashSet对HashMap的借用一样。
读懂HashMap的源码就可以轻松读懂LinkedHashMap,HashSet,LinkedHashSet的源码了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值