博客
关于我
java HashSet
阅读量:339 次
发布时间:2019-03-04

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

HashSet底层是HashMap的实现,这种基于哈希表的数据结构能够在O(1)的平均时间内完成插入、删除和查找操作。以下是具体的实现细节:

  • 构造器

    HashSet的构造器调用HashMap的构造器,初始化内部的哈希表。默认情况下,哈希表的大小为16(如果没有指定初始容量)。

  • 添加元素

    HashSet的add方法调用HashMap的put方法,将元素存储进哈希表。每次添加元素时,put方法会计算元素的哈希值,并找到对应的索引位置。如果该位置为空,则新建一个节点并存入;如果不为空,则检查该节点的键与新元素的键是否相同。如果相同,则返回false,否则返回true。

  • 哈希值计算

    HashMap使用 hashCode方法计算元素的哈希值,这个方法不仅考虑元素的内置hashCode,还对哈希值进行了位运算,以减少碰撞概率。

  • 存储逻辑

    put方法将元素存储到哈希表中,并在链表中添加新的节点。链表的最大长度为8,超过这个数目后,链表会被转换为红黑树,以减少查找时间。

  • 树化过程

    当链表长度达到8时,put方法会调用treeify方法,将链表转换为红黑树。这一过程确保了在高负载情况下的查找效率。

  • 扩容机制

    当哈希表的负载因素超过75%时,resize方法会被调用,将表扩展到下一个更大的大小,以确保有足够的空间存储新增的元素。

  • 迁移节点

    当表扩容时,旧表中的节点会被迁移到新表中,保持数据的完整性和一致性。

  • 通过以上机制,HashSet能够在高效的时间复杂度内完成各种集合操作,同时保持内存占用和操作的平衡性。

    转载地址:http://thce.baihongyu.com/

    你可能感兴趣的文章
    Phalcon环境搭建与项目开发
    查看>>
    Phantom.js维护者退出,项目的未来成疑
    查看>>
    phoenix无法连接hbase shell创建表失败_报错_PleaseHoldException: Master is initializing---记录020_大数据工作笔记0180
    查看>>
    Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
    查看>>
    phoenix连接hbase报错Can not resolve hadoop120, please check your network_记录026---大数据工作笔记0187
    查看>>
    Photoshop工作笔记001---Photoshop常用快捷键总结
    查看>>
    Reids配置文件redis.conf中文详解
    查看>>
    PHP
    查看>>
    Regular Expression Notes
    查看>>
    PHP $FILES error码对应错误信息
    查看>>
    PHP $_FILES函数详解
    查看>>
    php & 和 & (主要是url 问题)
    查看>>
    php -- 魔术方法 之 判断属性是否存在或为空:__isset()
    查看>>
    php -- 魔术方法 之 获取属性:__get()
    查看>>
    php -树-二叉树的实现
    查看>>
    PHP -算法-二路归并
    查看>>
    php 2条不一样 的json数据 怎么放在一个json里面_如果你是PHP开发者,请务必了解一下Composer...
    查看>>
    php 360 不记住密码,JavaScript_多种方法实现360浏览器下禁止自动填写用户名密码,目前开发一个项目遇到一个很 - phpStudy...
    查看>>
    regExp的match、exec、test区别
    查看>>
    PHP 5.3.0以上推荐使用mysqlnd驱动
    查看>>