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

HashMap - 底层原理

HashMap - 底层原理

HashMap底层用的就是hash表数据结构,即数组和链表或红黑树

  1. 当我们向HashMap中Put元素时,利用key的hashCode重新hash计算出当前对象的元素在数组中的下标

  2. 存储时,如果出现hash值相同的key,会有2种情况

    1. 如果key相同,那么就会覆盖原数据
    2. 如果key不相同,就说明出现了冲突,则将当前的key-value放入链表或红黑树中。(链表的长度大于8数组的长度大于64,那么链表才会转换为红黑树)
  3. 获取数据时,直接找到对应的hash值对应下标,再进一步判断key是否相同,从而找到对应值,如果是链表就要遍历链表查,如果是红黑树就要到红黑树中查

HashMap的jdk1.7和jdk1.8有什么区别?

jdk1.8之前,采用的是 hash表 +数组+链表,来解决hash冲突的问题,并没有采用红黑树。

jdk1.8以后,采用了红黑树+链表的方式,当链表的长度大于8,数组的长度大于64的时候,就会采用红黑树来解决问题。

HashMap的底层原理

  1. 底层采用hash表数据结构 + 数组 + (链表或红黑树)

  2. 添加数据时,计算key的hash值,找到数组的下标

    1. 如果key相同替换原内容
    2. key不同,存入链表或红黑树
  3. 获取数据,计算key的hash值,获取元素

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

相关文章:

  • Python第二次作业
  • Vspy使用教程
  • 通用网站模板网站备案要幕布照
  • 网站三要素关键词 描述怎么做青海项目信息网官网
  • JavaScript学习笔记(二十八):JavaScript性能优化全攻略
  • mooc自动互评脚本笔记---2025年10月11日
  • 什么是语言模型
  • 免费网站正能量不用下载网站程序是什么?
  • 海外住宅IP的分类方式
  • wpf之ToggleButton控件
  • 【传奇开心果系列】基于Flet框架实现的文件选择文件保存和目录选择的样例自定义模板特色和实现原理深度解析
  • 做网站什么数据库用的多低价建站在哪里买
  • 从零搭建 React Native 到项目运行全记录(0.73.6 稳定版)
  • HTML DOM 对象
  • 红日靶场(四)——个人笔记
  • b树,b+树,红黑树
  • win7 iis网站无法显示上海网站设计公司有哪些
  • 马来西亚代表团到访愿景娱乐 共探TikTok直播电商增长新路径
  • 唯识主义:哲学爱智慧本质的当代回归
  • 网站开发公司照片网站建设开发协议
  • 小网站模板网页传奇推荐
  • 支持400+格式!FileOptimizer文件一键压缩
  • 【Unity笔记】Unity Lighting Settings 全解析:一文读懂烘焙光照的每个参数(VR项目Lighting优化)
  • 全链路智能运维中的业务负载预测与弹性伸缩机制
  • 健康管理实训室建设方案:标准化构建与质量保障
  • 甘肃建设局网站wordpress获取文章来源
  • 超简洁网站网络软文营销
  • XXE 注入漏洞全解析:从原理到实战
  • edu div2 183个人笔记(目前只补到D,后续可能会更新)
  • MDK启动文件堆栈空间手动指定地址方法和验证