前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >HashMap的默认初始长度是多少?为什么?

HashMap的默认初始长度是多少?为什么?

作者头像
终有救赎
发布2023-10-16 10:23:17
4290
发布2023-10-16 10:23:17
举报
文章被收录于专栏:多线程

在面试中,经常遇到集合相关问题,集合中必定逃不掉HashMap,那简单的都懂,比如hashmap初始长度,大部分人都知道是16,那如果面试官问为什么呢?这个时候看到这篇文章的小伙伴就赚了,带你彻底了解懂hashmap的默认初始长度为什么是16

1. 默认长度是多少?

HashMap的默认初始长度是16,自动拓展和手动初始化时,长度必须是2的幂,即2^n (每次扩容都是以2的整数次幂扩容

2.为什么是16呢?

选择16是为了服务于从Key映射到index的Hash算法,在性能和内存的使用上取平衡,实现一个尽量均匀分布的Hash函数,选取16,是通过位运算的方法进行求取的。

3.详细讲解一下hash过程

Hash函数:index=Hash(Value)

位运算求HashMap函数,位运算:index=Hash数据(Key)&(length-1),进行的是二进制的与(&)运算

例如index=101111100100 1011 (Hash数据)&1111(默认长度16的二进制)=1011,结果取决于Value的最后四位,

1111是(Length-1)默认的Length是16,Length-1是15的二进制

使用位运算,效果上和取模(index=Hash数据(Key)%Length)相当,同时提高了性能

4.使用比16小的数看看会有什么问题?

设HashMap的长度是9,则

index=11100011010101(Hash数据)&1000(Length-1)=0000

设HashMap的长度是10,则

index=11100011010101(Hash数据)&1001(Length-1)=0001

设HashMap的长度是16,则

index=11100011010101(Hash数据)&1111(Length-1)=0101

5.分析

长度为9时,-000,的结果出现概率非常大,出现其他结果的概率很小

长度为10时,出现-00-,的结果概率很大,出现其他结果的概率较小

长度为16时,可能会出现各种结果出现,因为(Length-1=15) 15的二进制1111,可以出现所有结果,在Length为16的前提下,只要输入的Hash数据本身分布均匀,Hash算法的结果就是均匀的。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-10-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 默认长度是多少?
  • 2.为什么是16呢?
  • 3.详细讲解一下hash过程
  • 4.使用比16小的数看看会有什么问题?
  • 5.分析
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档