当前位置: 首页 > news >正文

HashMap的put方法的具体流程(高频)

1、判断键值对数组table是否为空或为null,否则执行resize()进行扩容(初始化)。

2、根据键值key计算hash值得到数组索引。

3、判断table[i] == null,条件成立,直接新建节点添加。

4、如果table[i] == null,不成立

   4.1、判断table[i]的首个元素是否和key一样,如果相同直接覆盖value;

   4.2、判断table[i]是否为treeNode,即table[i]是否是红黑树,如果是红黑树,则直接在树中插入键值对;

   4.3、遍历table[i],链表的尾部插入数据,然后判断链表长度是否大于8,大于8的话把链表转换为红黑树,在红黑树中执行插入操作,遍历过程中若发现key已经存在直接覆盖value。

5、插入成功后,判断实际存在的键值对数量size是否超多了最大容量threshold(数组长度*0.75),如果超过,进行扩容。

http://www.dtcms.com/a/479216.html

相关文章:

  • 龙岩做网站开发多久时间wordpress onethink
  • 自己建网站做淘宝客网站建设的要点是什么
  • 服务器里面如何做网站中国的网站域名是什么意思
  • MQTT和WebSocket的差别
  • org的域名网站导航网源码
  • 网站开发合同封面学会网站建设三方协议
  • wordpress登陆背景seo免费网站建设
  • 烟台企业自助建站系统wordpress最多支持多少会员
  • 计算机毕业设计选题推荐:基于SpringBoot+Vue的前后端分离网吧管理系统(附源码+文档+调试+讲解)
  • 常平镇网站建设wordpress get_user_id
  • 【FFmpeg】销毁解码器时,必须清理剩余帧吗?
  • 烟台网站制作建设医生可以自己做网站吗
  • CV论文速递:覆盖视频生成与控制、图像视频修复、AIGC检测与隐私保护等方向!(10.06-10.10)
  • 牙周探诊出血点与炎症活动性关联性的临床再评估
  • 网站和软件建站37网游
  • 游戏开发中的资源加载策略:懒加载 vs 预加载深度解析
  • 宁波中科网站建设有限公司建设网站开题报告
  • wsl打开vscode报错
  • 内网网站如何建设东莞营业厅
  • 网站搭建商上海郑州快速建站公司
  • 网站制作自学网网站开发需要花费
  • C++与Qt图形开发
  • 网站建设的工作描述公司外宣网站
  • 从零学算法51
  • (三)黑马React(封装axioas/用户登录RTK/Token持久化/表单提交)
  • 做纺织机械的网站域名中国互联网巨头有哪些
  • ORB-SLAM3 erros when run
  • 手机网站模板使用方法wordpress 主题 英文
  • [手写系列]Go手写db — — 第五版(实现数据库操作模块)
  • 网站购买域名朝阳企业网站建设