码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Map集合源码分析


    目录

    1、map存储特点:

    2、hashMap底层

    3、hashTable

    4、TreeMap源码


    1、map存储特点:

    (1)k-v存储,最后是存储在HashMap$Node=newNode(hash,key,value,null);

    (2)k-v为方便遍历,还会创建EntrySet集合,该集合存放Entry,一个Entry对象就有k-v;

    (3)当把HashMap$Node对象存放到entrySet就方便我们遍历,因为Map.Entry提供了getKey()方法和getValue()方法

    (4)map中,key相同,值覆盖,如下方法:

    ①记录旧值;

    ②值替换为新加入的值

    (5)HashMap没有实现同步,不是线程安全,底层是以hash表来存储(数组+链表+红黑树)

    2、hashMap底层

    (1)执行构造器,初始化加载因子loadfactor=0.75

    (2)执行put()方法

    (3)计算key的hash值

    (4)执行putVal()方法

    ①判断表是否为空,为空

    ②判断该hash位置是否为空,为null,将添加值放入

    ③判断table的索引位置的key的hash值和新的key的hash值相同相同,并且满足现有的节点的key和准备添加节点的key是同一个对象||equals相同,就只能替换key-value;

    ④如果当前table的节点已经是红黑树,就按照红黑树方法处理

    ⑤如果找到的节点后面是链表,就循环比较:

    A、若整个链表没有和他相同,加到该链表的最后,加入后,判断当前链表个数是否已经8个,超过后进行红黑树树化treeifBin();

    B、如果在循环比较中,发现有相同,不添加break,只是替换value

    树化,若表为空或表长小于64,就不会树化,而是进行扩容

    ⑥增加修改次数和数组大小,判断是否需要扩容

    3、hashTable

    (1)特点:

    ①键和值不能为null;

    ②是线程安全;

    ③底层是一个数组,HashTable$Entry,初始化大小为11;

    (2)底层:

    执行addEntry()添加k-v封装到Entry

    rehash()方法扩容,按照两倍+1扩容

    4、TreeMap源码

    把传入的实现Comparator接口的匿名内部类,传给TreeMap

    添加的元素

  • 相关阅读:
    机器学习笔记 YOLOv9模型相关论文简读
    随机森林实战案例——对天气最高温度进行预测
    合并请求格式太乱?工单内容各写各的?表单模板来帮你
    现代企业管理笔记——领导
    2022 年最值得关注的颠覆性技术
    那些年遇到过的问题与解决方案
    持久与速度 鱼和熊掌 MySQL怎么去兼得
    可视化会议网站导读
    3、Android 活动Activity(4)(为活动补充附加信息)
    Dubbo框架实现RPC远程调用包括nacos的配置和初始化
  • 原文地址:https://blog.csdn.net/weixin_50616848/article/details/126796164
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号