重学java 57.哈希表结构存储过程

别焦虑,生活无非见招拆招

------ 24.6.3

哈希表存储数据去重复的过程:

a.先比较元素的哈希值(重写hashCode),再比较内容(重写equals)

b.如果哈希值不一样,证明内容不一样,存

c.如果哈希值一样,再比较内容

如果哈希值一样,内容不一样(哈希碰撞,哈希冲突),存

如果哈希值一样,内容也一样,去重复

细节:

a.哈希表中的数组默认长度16,但是是第一次put的时候数组才会被初始化为长度为16的数组

b.哈希表中有一个加载因子: 0.75F含义是,数组存储达到百分之75的时候,扩容扩容2倍

c.如果链表长度达到 8**,** 并且数组容量大于等于 64的时候,链表会自动转成红黑树

d.如果删除元素,元素个数小于等于 6了,红黑树会转回链表

变量

default_initial_capacity :HashMap默认容量 16

default_load_factor :HashMap默认加载因子 0.75f

threshold :扩容的临界值 等于容量*0.75=12第一次扩容

treeify_threshold :链表长度默认值,转为红黑树 :8

min_treeify_capacity :链表被 化时最小的数组容量:64

相关推荐
@Aurora.4 小时前
优选算法【专题九:哈希表】
算法·哈希算法·散列表
Hello World . .4 小时前
数据结构:队列
c语言·开发语言·数据结构·vim
you-_ling7 小时前
数据结构:4.二叉树
数据结构
senijusene8 小时前
数据结构与算法:队列与树形结构详细总结
开发语言·数据结构·算法
青桔柠薯片8 小时前
数据结构:队列,二叉树
数据结构
杜家老五8 小时前
综合实力与专业服务深度解析 2026北京网站制作公司六大优选
数据结构·算法·线性回归·启发式算法·模拟退火算法
寄存器漫游者8 小时前
数据结构:带头节点单链表
c语言·数据结构
鹿角片ljp8 小时前
力扣9.回文数-转字符双指针和反转数字
java·数据结构·算法
梦梦代码精9 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
80530单词突击赢12 小时前
C++哈希表实现:开散列与闭散列详解
算法·哈希算法·散列表