hashmap面试问题

Q:为什么扩容要以2的次幂*?

A: 1.因为在计算数组下标时用到的函数是H & (length -1),如果是奇数的话-1后的2进制末尾是0,这样在于hashcode做与操作时永远都是0,这样会造成分布不均匀
2.当hashmap做扩容的时候,数组容量如果非2的次幂的话,需要每次对所有元素进行重新计算,这样效率会很低,而2的次幂的话,只需看元素hashcode末位是否为如果为1,新数组的下标不变,0=当前数组下标+老数组的长度

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值