HashSet实现基于HashMap
2016-04-21 00:00
281 查看
HashSet的部分源码:
这是里面其中的一部分代码(去掉了注释).
可以看出HashSet是通过储存map的key来并且value是
达到键值对的。
每次的存储,都是通过
如果该set中不存在该key的元素则返回 true否者返回false
其他的的contains 、size 、remove等都是通过使用map对应的方法实现。
static final long serialVersionUID = -5024744406713321676L; private transient HashMap<E,Object> map; private static final Object PRESENT = new Object(); public HashSet() { map = new HashMap<>(); } public HashSet(Collection<? extends E> c) { map = new HashMap<>(Math.max((int) (c.size()/.75f) + 1, 16)); addAll(c); } 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); } public Iterator<E> iterator() { return map.keySet().iterator(); } public int size() { return map.size(); } public boolean isEmpty() { return map.isEmpty(); } public boolean contains(Object o) { return map.containsKey(o); } 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(); }
这是里面其中的一部分代码(去掉了注释).
可以看出HashSet是通过储存map的key来并且value是
private static final Object PRESENT = new Object();
达到键值对的。
每次的存储,都是通过
public boolean add(E e) { return map.put(e, PRESENT)==null; }
如果该set中不存在该key的元素则返回 true否者返回false
其他的的contains 、size 、remove等都是通过使用map对应的方法实现。
相关文章推荐
- MyBatis Generator generatorConfig.xml配置
- Gson 工具类
- vim常用快捷键
- Java爬虫框架:SeimiCrawler——结构化解析与数据存储
- MCV的优缺点
- 第三天
- Servlet 重温
- 打包jar包含依赖jar设置
- classOf、getClass
- 解决IE6双边距问题
- Nginx安装
- Nginx常用命令
- Java对象内存分配原理及源码分析
- java大牛博客
- jdbc出现错误Before start of result set Query: select *
- jdk代理的问题
- java 中两种多线程的区别,start方法和run方法的启动区别
- 不成熟的人为了伟大的事业而死去,成熟的人为了伟大的事业而卑贱地活着
- 关于List接口中ArrayList,LinkedList和Vector的取值方法的一些性能测试
- 【JBehave】表格形式的story参数示例