如何用源码分析HashSet
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,本篇文章为大家展示了如何用源码分析HashSet,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。HashSet简介public class HashSet
千家信息网最后更新 2025年01月23日如何用源码分析HashSet
本篇文章为大家展示了如何用源码分析HashSet,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
HashSet简介
public class HashSetextends AbstractSet implements Set , Cloneable, Serializable {}
HashSet继承了AbstractSet,实现了Set; 是一个由HashMap实现的没有重复元素的集合
不保证元素顺序,允许使用null元素
HashSet实现了Cloneable接口,重写了clone方法,因此可以进行克隆。
HashSet实现了Serializable接口,因此可以进行序列化。
HashSet的操作是非线程安全的
成员变量
/** 具体存储HashSet元素的HashMap **/private transient HashMapmap;/** 由于Set只用到了HashMap的key 所以用PRESENT来填充HashMap的Value **/private static final Object PRESENT = new Object();
构造函数
/** 默认构造函数 采用HashMap的默认构造函数 **/public HashSet() { map = new HashMap<>();}/** 通过集合构造HashSet 先根据集合大小计算HashMap的大小值 初始化HashMap后将集合元素全部添加进去 **/public HashSet(Collection extends E> c) { map = new HashMap<>(Math.max((int) (c.size()/.75f) + 1, 16)); addAll(c);}/** 根据初始化容量构造HashMap **/public HashSet(int initialCapacity) { map = new HashMap<>(initialCapacity);}/** 根据初始化容量和加载因子构造HashMap **/public HashSet(int initialCapacity, float loadFactor) { map = new HashMap<>(initialCapacity, loadFactor);}/** 同上面构造函数 dummy参数无实际意义 主要供LinkedHashSet调用 底层采用LinkedHashMap **/HashSet(int initialCapacity, float loadFactor, boolean dummy) { map = new LinkedHashMap<>(initialCapacity, loadFactor);}
由于底层采用HashMap 构造函数主要构造HashMap。
最后一个构造函数主要供子类LinkedHashSet调用,底层采用LinkedHashMap
元素添加
/** 添加元素 通过HashMap的put方法实现 **/public boolean add(E e) { return map.put(e, PRESENT) == null;}
元素移除
/** 移除元素 **/public boolean remove(Object o) { return map.remove(o) == PRESENT;}/** 清空元素 **/public void clear() { map.clear();}
查找元素
/** 查找元素 **/ public boolean contains(Object o) { return map.containsKey(o);}
其它接口
/** 返回迭代器 **/public Iteratoriterator() { return map.keySet().iterator();}/** 获取HashSet中元素的数量 **/public int size() { return map.size();}/** 返回HashSet中是否是空的 **/public boolean isEmpty() { return map.isEmpty();}
上述内容就是如何用源码分析HashSet,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
元素
函数
底层
接口
源码
分析
内容
大小
容量
技能
方法
知识
简明
安全
简明扼要
参数
变量
因子
子类
实际
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络技术能去学什么
服务器搬家
服务器集群资源不够扩容方案
柯美226服务器扫描
家有服务器
虚拟化和服务器配置
吉林通讯软件开发参考价格
如何连接多个数据库源
西安汇丰软件开发职级划分
数据库如何对不同身份划分权限
常用的医学文献数据库
参观成都网络安全博览会
清华学数据库怎么样
中学生网络安全赛事
软件开发工资
excel链接修改数据库
数据库原理与设计练习题目
帝国cms数据库配恢复
互联网软件开发学什么编程语言好
关于计算机网络技术的理想
数据库er模型组成要素
小学生网络安全知识十条
安徽多功能软件开发服务价格
换手机应用带数据库
c 数据库时间比较大小
市县两级网络安全和舆情处置
中学生网络安全赛事
杭州软件开发上市公司有哪些
七日杀卡在配置文件进不去服务器
服务器安全狗无法使用