HashSet源码学习
时间:2022-07-23
本文章向大家介绍HashSet源码学习,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
经过前两次的HashMap和HashTable的学习,我们准备将HashSet也进行学习一下,本着之间差异不是特别大的前提。但是实际上是这样吗?我们知道set就是集合,set是不允许相同的,set是List的变种,是又list改变而来,具体来说就是在添加的时候会先判断是否具有重复元素。那么HashSet是否就是Hash算法与Set结合而来的一种寻址快捷的集合呐?带着这样的疑问我们学习一下HashSet的源码吧。
从源码的结构来看,HashSet真的没有多少代码。但是我们发现其中有一个Map,莫非HashSet是从Map演变而来?
//默认初始化一个HashMap
public HashSet() {
map = new HashMap<>();
}
//0.75的比列进行扩容,这里的默认容量应该是16,因为要和HashMap保持一致
public HashSet(Collection<? extends E> c) {
map = new HashMap<>(Math.max((int) (c.size()/.75f) + 1, 16));
//将传入的集合添加到map中
addAll(c);
}
//按照标准的方式初始化这个HashMap
public HashSet(int initialCapacity, float loadFactor) {
map = new HashMap<>(initialCapacity, loadFactor);
}
public HashSet(int initialCapacity) {
map = new HashMap<>(initialCapacity);
}
//这里的第三个参数好像没用到哦
HashSet(int initialCapacity, float loadFactor, boolean dummy) {
map = new LinkedHashMap<>(initialCapacity, loadFactor);
}
可以看出,HashSet其实是从HashMap演变而来的。而不是list,我记得之前分析的时候说的set都是基于List的结论。看来并不能这样以偏概全。
在添加的方法中,我们发现其实也是调用的map的put方法。但是这里的Present其实是一个静态变量,也就是在这个map中value是一样的,不同的是key的值,也就是hashSet使用的仅仅是HashMap的key。
public boolean add(E e) {
return map.put(e, PRESENT)==null;
}
由于只是使用的key,所以remove之后返回来的必然是present。也就是true了。
public boolean remove(Object o) {
return map.remove(o)==PRESENT;
}
这块没有提供get方法,按理说应该有get方法呀,否则的话就只能通过迭代器进行访问。这样是比较麻烦的呀。这也可能就是set这种数据类型的特点吧,从这个角度看,我们在使用set的时候标准的姿势应该是仅仅作为去重的一种数据结构。这也是set这种数据结构的功能。
- 挖洞经验 | 记一次针对Twitter(Periscope)API 的有趣挖洞经历
- 设计模式学习(二): 观察者模式 (C#)
- Carbondata源码系列(一)文件生成过程
- BoopSuite:基于Python编写的无线安全审计套件
- 设计模式学习(一):多用组合少用继承(C#)
- 在asp.net web api 2 (ioc autofac) 使用 Serilog 记录日志
- hbase源码系列(十三)缓存机制MemStore与Block Cache
- hbase源码系列(十四)Compact和Split
- 设计模式学习(四): 1.简单工厂 (附C#实现)
- 从头编写 asp.net core 2.0 web api 基础框架 (5) EF CRUD
- 从头编写 asp.net core 2.0 web api 基础框架 (4) EF配置
- RavenDb学习(十)附件,存储大对象
- 从头编写 asp.net core 2.0 web api 基础框架 (3)
- Distribute Cached 使用
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- JS+CSS 3实现图片滑块效果
- 深入理解 AuthenticationManagerBuilder 【源码篇】
- 每天一道前端面试题:如何进行网站性能优化
- PowerBI DAX 度量值管理 - 驾驭度量值依赖关系,删除无效
- Git 实用命令小抄
- 手把手教你画酷炫环形图(图文详解)
- 为什么说神经网络可以逼近任意函数?
- 缩放|位移|渐变简单动画
- HTTP状态码及其含义
- 卷积神经网络中的参数共享/权重复制
- 前端面试基础题:从浏览器地址栏输入url到显示页面的步骤
- 学会这15个TS面试题,拿到更高薪的offer
- 前端面试基础题:请描述⼀下 cookies , sessionStorage 和 localStorage 的区别?
- matplotlib基础绘图命令之pie
- 【从0到1学算法】快速排序