HashSet源码

1、HashSet介绍

与HashMap类似,字面上看,HashSet由两个单词组成:HashSet。其中,Set表示接口,实现Set接口也有多种方式,各有特点,HashSet实现的方式利用了Hash

Set public interface Set<E> extends Collection<E> {

表示容器没有重复元素、且不保证顺序的容器接口,它扩展了Collection,但没有定义任何新的方法、

无顺序,不重复

与`HashMap类似,HashSet要求元素重写hashCode和equals方法,且对于两个对象,如果equals相同,则hashCode也必须相同,如果是自定义的类,需要注意这一点

HashSet的应用场景

  • 排重
  • 保存特殊值
  • 集合运算

底层就是一个HashMap

2、构造函数

HashSet的内部是用HashMap实现的,它内部有一个HashMap实例变量

同时,这个HashMap所有键对应的值固定

  //HashSet内部使用HashMap实现,它的内部有一个HashMap实例变量
    private transient HashMap<E,Object> map;

//Map有键和值,HashSet相当于只有键,都是相同的固定值,
    private static final Object PRESENT = new Object();

HashSet的构造方法,主要就是调用了对应的HashMap的构造方法

2.1、HashSet

 public HashSet() {
        map = new HashMap<>();
    }

2.2public HashSet(int initialCapacity, float loadFactor) {

   public HashSet(int initialCapacity, float loadFactor) {
        map = new HashMap<>(initialCapacity, loadFactor);
    }

2.3、public HashSet(int initialCapacity) {

   public HashSet(int initialCapacity) {
        map = new HashMap<>(initialCapacity);
    }

2.4、 public HashSet(Collection<? extends E> c) {

    public HashSet(Collection<? extends E> c) {
        // c.size()/0.75用于计算initialCapacity,0.75f是loadFactor的默认值
        map = new HashMap<>(Math.max((int) (c.size()/.75f) + 1, 16));
        //添加元素
        addAll(c);
    }

3、add方法

    public boolean add(E e) {
        //就是map调用的put元素,元素e用于键,值就是固定的PRESENT,
        // put返回null表示原来没有对应的键,添加成功了。
        return map.put(e, PRESENT)==null;
    }

4、remove方法

    public boolean remove(Object o) {
        //就是调用map的remove方法,返回值为PRESENT表示原来有对应的键且删除成功
        return map.remove(o)==PRESENT;
    }

5、contains

    public boolean contains(Object o) {
        //就是检查map中是否包含对应的键
        return map.containsKey(o);
    }

6、小结

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vVuy0RCe-1582541662696)(images/06.png)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值