美文网首页
HashSet 源码分析

HashSet 源码分析

作者: haloSky_life | 来源:发表于2020-05-16 19:15 被阅读0次

在JDK1.8的文档中是这么介绍HashSet的:此类实现Set接口,由哈希表(实际为HashMap实例)支持。 对集合的迭代次序不作任何保证;
这个类提供了基本操作(add,remove,contains和size)固定的时间性能,假定哈希函数将分散的桶中正确的元素。 迭代此集合需要与HashSet实例的大小(元素数量)和后台HashMap实例(桶数)的“容量”的总和成比例的时间。 因此,如果迭代性能很重要,不要将初始容量设置得太高(或负载因子太低)是非常重要的。
在文档的介绍中,我们能直观的发现HashSet的几个特点:
1.不能重复
2.不能保证添加的顺序跟集合中的排序一样
3.如果迭代性能很重要,不能把初始容量设置的太高或负载因子太低

HashSet的属性

// 存储数据的map
private transient HashMap<E,Object> map;
// HashSet中存储的元素,都是Map的key,这个属性为每个key的value
private static final Object PRESENT = new Object();

HashSet的构造器:

public HashSet() {
    // 初始化map
    map = new HashMap<>();
}

public HashSet(Collection<? extends E> c) {
    // 传入一个目标集合的话,会给map一个初始容量。容量取决于 : (c.size / 0.75+1) > 16 ? (c.size / 0.75+1) : 16 
    map = new HashMap<>(Math.max((int) (c.size()/.75f) + 1, 16));
    addAll(c);
}

public boolean addAll(Collection<? extends E> c) {
    boolean modified = false;
    for (E e : c)
        if (add(e))
            modified = true;
    return modified;
}

public boolean add(E e) {
    return map.put(e, PRESENT)==null;
}

HashSet(Collection<? extends E> c):构建一个包含目标集的HashSet, HashMap的初始容量根据目标集大小来定,加载因子为HashMap 的默认大小 0.75,然后对for循环添加进HashMap中(关于是怎么添加的,这个写HashMap的再说)。

add(E e): 添加元素

public boolean add(E e) {
    return map.put(e, PRESENT)==null;
}

remove(Object o): 删除元素

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

算了算了~~整个HashSet 都是根据HashMap来实现的,其实我应该先写HashMap的。算了,就当是自己看过HashSet的一个痕迹吧 -_-||

总结:
1.HashSet 不会产生重复的元素
2.HashSet 的元素序列不是按照添加的顺序
(就不写什么添加啊删除的效率高了,屁都没看就说效率高,太扯蛋了 ==)

相关文章

  • Java集合之HashSet源码分析

    阅读目录 一、HashSet简介 二、HashSet源码分析 三、HashSet的应用示例代码

  • Java 集合类原理

    Java基础——HashMap源码分析 Java基础——HashSet源码分析 Java基础——HashTable...

  • Java容器类框架分析(5)HashSet源码分析

    概述 在分析HashSet源码前,先看看HashSet的继承关系 从上图可以看出,HashSet继承自Abstra...

  • HashSet实现原理分析(Java源码剖析)

    本文将深入讨论HashSet实现原理的源码细节。在分析源码之前,首先我们需要对HashSet有一个基本的理解。 H...

  • Java集合源码分析-TreeSet

    上篇文章分析完HashSet和LinkedHashSet的源码,我们清楚:HashSet是无序的、不重复的、允许最...

  • HashSet源码分析

    HashSet是基于HashMap实现的,底层采用HashMap来保存元素,本篇文章需要在HashMap的基础上进...

  • HashSet源码分析

    从源码中可以看出, HashSet实现的功能通过重用HashMap去实现对应的功能。但是和HashMap实现的接口...

  • HashSet源码分析

    HashSet HashSet概述### HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)...

  • HashSet源码分析

    Set集合的最主要特性就是没有重复元素,HashSet是Set的一个字类,其内部基于HashMap实现 1. 成员...

  • HashSet源码分析

    源码来自jdk1.8 HashSet实现了Set接口 内部由一个HashMap实现 允许一个null值 不同步 a...

网友评论

      本文标题:HashSet 源码分析

      本文链接:https://www.haomeiwen.com/subject/whbrohtx.html