网站首页 > 文章精选 正文
前言
HashSet是Set接口的一个实现类,实际上它是hashMap的实例,不保证顺序,且非线程安全的。jdk文档中也足以说明这一点。而HashSet常用的方法有add, remove, contains和size。
案例使用
源码分析
1、new HashSet<>();
// private transient HashMap<E,Object> map;
//这里也足以说明HashSet是个HashMap实例,那么是怎么实现的呢?
//下面会有分析
public HashSet() {
map = new HashMap<>();
}
2、java.util.HashSet#add
//这里直接调用了map的put方法,e就是key
//那么PRESENT是啥?原来PRESENT=new Object
// private static final Object PRESENT = new Object();
public boolean add(E e) {
return map.put(e, PRESENT)==null;
}
3、java.util.HashSet#remove
public boolean remove(Object o) {
return map.remove(o)==PRESENT;
}
4、java.util.HashSet#contains
public boolean contains(Object o) {
return map.containsKey(o);
}
5、java.util.HashSet#size
public int size() {
return map.size();
}
6、java.util.HashSet#iterator
//说明迭代器是迭代了map的keySet
//从HashMap的源码分析可以知道,key是不可以重复的
//所以HashSet是不存在重复的值
public Iterator<E> iterator() {
return map.keySet().iterator();
}
总结
HashSet是HashMap的实例,HashSet存储的数据是不可重复的。且HashSet很多方法都直接调用HashMap的方法。HashSet的值是HashMap的key,而HashMap的值是一个Object。类似一个占位的作用。
喜欢这样做源码解析的同学,可以点赞、关注+收藏,后期还会推出其他框架源码分析。
如果有补充的地方,留言区见。
- 上一篇: Java 线程安全思路
- 下一篇: C# 线程安全并发集合使用的简单例子
猜你喜欢
- 2025-01-07 三万字总结最全Java线程池源码面试题
- 2025-01-07 12分钟从Executor自顶向下彻底搞懂线程池
- 2025-01-07 实战录 | Kafka-0.10 Consumer源码解析
- 2025-01-07 疯狂Java讲义笔记汇总
- 2025-01-07 撸完这篇线程池,我快咳血了
- 2025-01-07 100个Java工具类之1:多种集合类型实现排序功能
- 2025-01-07 100个Java工具类之8:java.util包下的Collections
- 2025-01-07 C# 可用在多线程环境中并发集合
- 2025-01-07 关于HashMap与HashSet的底层实现原理
- 2025-01-07 100个Java工具类之58:集合HashSet
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 稳压管的稳压区是工作在什么区 (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)