HashTabld底层源码解读
创始人
2025-06-01 02:30:57
0

Java源码系列:下方连接
http://t.csdn.cn/Nwzed


文章目录

  • 前言
  • 一、HashTabld源码解读
  • 二、HashTabld put( )源码解读
  • 二、HashTable添加重复的元素
  • 总结


前言

提示:三个工作日之后总结


提示:以下是本篇文章正文内容,下面案例可供参考

一、HashTabld源码解读

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、HashTabld put( )源码解读

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

来到 put 方法,有同步关键字修饰表示这个方法是线程安全的。

在这里插入图片描述
但上图大概是说:先获取到当前的整个table数组,再让当前的 key通过hashCode获取hash值,拿着hash值和数组的长度计算出下标落点,获取到下标落点的 entry对象映射的Node节点内容,如果entry不等于null,就让ntery指向下一个元素,当然第一次进来entry肯定为空的,为空说明计算的下标落点没有节点驻足,将hash值和计算出的下标落点一并打包进行节点的添加。
在这里插入图片描述
来到addEntry方法还是经典的先获取table的数组,判断是否需要进行扩容,这里第一次添加肯定是不需要的,当 count大于等于扩容因子(0.75)计算出的值 threshold(8) 时就需要进行扩容,需要扩容就会调用 rehash()方法进行数组的扩容,第一次进来肯定不会进行扩容,将 tab[index] 处的 Entry对象获取,由于这是第一次 e 肯定是 null,然后将 new Entry 放入计算出的下标落点。但如果获取原来的下标落点的 e 对象不为 null 呢,会将原来的 节点放入新增节点的后面

在这里插入图片描述
最后我们再来看一下 HashTable是怎么扩容的。
在这里插入图片描述

在这里插入图片描述

二、HashTable添加重复的元素

在这里插入图片描述

在这里插入图片描述

总结

提示:

上一篇:刷题(一)

下一篇:QuestDb 基础使用

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...