HashTabld底层源码解读
创始人
2025-06-01 01:32:39

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添加重复的元素

在这里插入图片描述

在这里插入图片描述

总结

提示:

相关内容

热门资讯

2025新版教程“奥云柳河麻将... 无需打开直接搜索微信:奥云柳河麻将有挂吗本司针对手游进行,选择我们的四大理由:1、软件助手是一款功能...
2025新版教程“人人南通长牌... 亲,人人南通长牌这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好...
2025新版教程“越乡游斗地主... 2025新版教程“越乡游斗地主到底是不是有挂”确实真的有挂(详细教程)是一款可以让一直输的玩家,快速...
2025新版教程“椰岛常胜麻将... 无需打开直接搜索微信:椰岛常胜麻将有挂吗本司针对手游进行,选择我们的四大理由:1、软件助手是一款功能...
2025新版教程“口袋上饶棋牌... 您好:口袋上饶棋牌这款游戏可以开挂,确实是有挂的,需要了解添加微信【29290261很多玩家在这款游...