JAVA源码学习之集合-Set总结

本文探讨了三种Set实现类的共性和区别,包括HashSet基于HashMap,TreeSet基于TreeMap,LinkHashSet的有序特性。重点比较了它们的底层数据结构和特性差异。

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

前言

前面几章我们研究了,Set的三个实现类,这章我们做下对比

正文

相同点

HashSet、LinkHashSet、TreeSet都是通过Map的实现类来实现的,不可重复的能力, 是根据相关Map实现类的key不可重复来实现的, 相关的方法都是通过Map实现类来实现的

不同点

HashSet和TreeSet区别

1. HashSet是基于HashMap实现的, TreeSet是基于TreeMap实现的

2. HashSet的key可以允许null, TreeSet的key不可以为null

所以说HashSet和TreeSet的区别其实就是 HashMap和TreeMap的区别

HashSet和LinkHashSet的区别

LinkHashSet是HashSet的子类,然后LinkHashSet是通过HashSet的HashMap的子类LinkHashMap来实现的,所以LinkHashSet的方法基本都是其父类的方法。

LinkHashSet和HashSet的区别可以看做是HashMap和LinkHashMap的区别, LinkHashMap的HashMap的基础上加入了双向链表的概念,来实现key的有序性,这一点也是LinkHashSet和HashSet的区别

关于map的相关问题,我们会在Map的章节中进行研究

下一章我们就好开始collection中最神秘的Queue的研究了

上一章                                                                                                                                 下一章

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值