博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java.util.HashSet源码分析
阅读量:6275 次
发布时间:2019-06-22

本文共 1758 字,大约阅读时间需要 5 分钟。

public class HashSet
extends AbstractSet
implements Set
, Cloneable, java.io.Serializable

HashSet实现Set接口,内部维护一个HashMap实例变量。不保证顺序,允许null元素。

对于基本的操作,如add,remove,contains,size,只需要常量的时间复杂度。

不是线程安全的,如果在多线程环境下,需要被同步化,如调用方法Collections.synchronizedSet(new HashSet())。

HashSet的迭代器是快速失败的,如果一个HashSet在迭代器被创建后被改变(不是使用迭代器的remove方法),迭代器会抛出ConcurrentModificationException。

 

private transient HashMap
map;// Dummy value to associate with an Object in the backing Mapprivate static final Object PRESENT = new Object();

两个实例变量,map是内部维护的HashMap,PRESENT是放到HashMap的value的变量。

 

5个构造器:

//空set, map对象的初始容量16,负载因子0.75public HashSet() {    map = new HashMap<>();}public HashSet(Collection
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);}//初始化容量,使用默认负载因子0.75public HashSet(int initialCapacity) { map = new HashMap<>(initialCapacity);}//使用LinkedHashMap,dummy参数的作用只是与使用HashMap实现的构造器有不一样的方法签名HashSet(int initialCapacity, float loadFactor, boolean dummy) { map = new LinkedHashMap<>(initialCapacity, loadFactor);}

 

//使用的是HashMap的键集合,返回的迭代器是键集合的迭代器public Iterator
iterator() { return map.keySet().iterator();}

 

//放进map的键值对是,参数e和常量PRESENT,所有键值对的值都是同一个Object对象public boolean add(E e) {    return map.put(e, PRESENT)==null;}

如果元素e已经存在HashSet之中,不改变Set并返回false,如果e不在HashSet之中,返回true

 

public boolean remove(Object o) {    return map.remove(o)==PRESENT;}

如果o在HashSet中,返回值是true,否则为false

 

还有一些其他方法没列出来,如size,isEmpty。

HashSet有实现Clonable接口,所以有clone方法,实现Serializable接口,所以有writeObject,readObject序列化反序列化方法。

转载于:https://www.cnblogs.com/13jhzeng/p/5793859.html

你可能感兴趣的文章
Firefox 是 Pwn2own 2014 上攻陷次数最多的浏览器
查看>>
阿里感悟(十八)- 应届生Review
查看>>
《计算广告:互联网商业变现的市场与技术》一第一部分 在线广告市场与背景...
查看>>
话说模式匹配(5) for表达式中的模式匹配
查看>>
《锋利的SQL(第2版)》——1.7 常用函数
查看>>
《Arduino家居安全系统构建实战》——1.5 介绍用于机器学习的F
查看>>
jquery中hover()的用法。简单粗暴
查看>>
线程管理(六)等待线程的终结
查看>>
spring boot集成mongodb最简单版
查看>>
DELL EqualLogic PS存储数据恢复全过程整理
查看>>
《Node.js入门经典》一2.3 安装模块
查看>>
《Java 开发从入门到精通》—— 2.5 技术解惑
查看>>
Linux 性能诊断 perf使用指南
查看>>
实操分享:看看小白我如何第一次搭建阿里云windows服务器(Tomcat+Mysql)
查看>>
Sphinx 配置文件说明
查看>>
数据结构实践——顺序表应用
查看>>
python2.7 之centos7 安装 pip, Scrapy
查看>>
机智云开源框架初始化顺序
查看>>
Spark修炼之道(进阶篇)——Spark入门到精通:第五节 Spark编程模型(二)
查看>>
一线架构师实践指南:云时代下双活零切换的七大关键点
查看>>