HashMap初始容量为什么是16(必须是2的幂次方)?

HashMap初始容量为什么是16(必须是2的幂次方)?

 /**
   * The default initial capacity - MUST be a power of two.
   */
static final int DEFAULT_INITIAL_CAPACITY = 1 << 4; // aka 16

关键词

  1. hash碰撞
  2. 位与运算(&)

原因

在HashMap中会存在如下代码(详情参考HashMap源代码)

... (n - 1) & hash ...

在执行上述代码的时候,会进行位与运算,n为容量大小,n=16,对应的二进制是 01111 。

1.    当n是2的幂次方时(16):

  • 01111 & 00101 = 00101
  • 01111 & 01010 = 01010
  • 01111 & 01101 = 01101
  • 01111 & 00111 = 00111
  • ...   

2.   当n不是2的幂次方时(11):

  • 01011 & 00101 = 00001
  • ​01011 & 01010 = 01010
  • 01011 & 01101 = 01001
  • 01011 & 01001 = 01001
  • ...

从上边可以看出:n不是2的幂次方时,会出现不同值得到相同的结果,这种现象叫做hash碰撞。在

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值