HashMap的长度为什么是2的幂次方
发表于:2025-02-12 作者:千家信息网编辑
千家信息网最后更新 2025年02月12日,本篇文章为大家展示了HashMap 的长度为什么是2的幂次方,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。为了能让 HashMap 存取高效,尽量较少碰撞,也
千家信息网最后更新 2025年02月12日HashMap的长度为什么是2的幂次方
本篇文章为大家展示了HashMap 的长度为什么是2的幂次方,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
为了能让 HashMap 存取高效,尽量较少碰撞,也就是要尽量把数据分配均匀。我们上面也讲到了过了,Hash 值的范围值-2147483648到2147483647,前后加起来大概40亿的映射空间,只要哈希函数映射得比较均匀松散,一般应用是很难出现碰撞的。但问题是一个40亿长度的数组,内存是放不下的。所以这个散列值是不能直接拿来用的。用之前还要先做对数组的长度取模运算,得到的余数才能用来要存放的位置也就是对应的数组下标。这个数组下标的计算方法是" (n - 1) & hash
"。(n代表数组长度)。这也就解释了 HashMap 的长度为什么是2的幂次方。
这个算法应该如何设计呢?
我们首先可能会想到采用%取余的操作来实现。但是,重点来了:"取余(%)操作中如果除数是2的幂次则等价于与其除数减一的与(&)操作(也就是说 hash%length==hash&(length-1)的前提是 length 是2的 n 次方;)。" 并且 采用二进制位操作 &,相对于%能够提高运算效率,这就解释了 HashMap 的长度为什么是2的幂次方。
上述内容就是HashMap 的长度为什么是2的幂次方,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
长度
数组
也就是
下标
内容
技能
知识
除数
碰撞
解释
运算
松散
简明
简明扼要
也就是说
二进制
代表
位置
余数
内存
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
吴江财务机器人rpa软件开发
社区团购软件开发流程
查指定数据库的表空间
网络安全和信息化领导小组汇报稿
厦门迪奥软件开发公司郭小平
银行里做软件开发需要加班吗
数据库宏分为三类
radius双因子服务器
我的世界生存服务器
邹鸿男 网络安全保卫局
数据库sql插入命令
数据库教程下载
怎么做好网络安全产品销售
免下载软件开发
vb数据库怎么显示备份
区分数据库
网络安全品牌商标
网络技术与应用基础
网络安全三年计划
超凡搜索怎么服务器正在连接
播放器视频软件开发
济南软件ios软件开发
服务器内存要插满么
医院住院管理系统数据库总结
网络安全专业教育部评级
国际版黏土服务器
石龙湖服务器
怀柔区智能网络技术怎么样
企业管理数据库怎么用
网络安全走进乡村课堂