HashMap中的tableSizeFor(int cap)方法介绍

代码示例:

在这里插入图片描述
乍一看到这个方法还是有点蒙的,这是要干啥

n |= n >>> 1;
  1. 分开看 n >>> 1 这里可以理解,是将n进行右移一位
    举个例子:如果n = 64 那么进行n >>> 1的操作后n的值变成了32
  2. 再看 n |= a 这里的意思就是就是n和a两个值进行按位或操作,然后将值复制给n,可以把它大概理解成n+=a
  3. 这里就可以大概理解上面的一串代码是干什么的了,这段代码的意思就是将n的二进制数所有的0变成1
  4. 看完最蒙的一段代码后,剩下的就比较好解释了cap - 1的意思就是防止cap本身就是2的整数次幂,经过后面一段代码后变成2的n+1次幂。
  5. 最后return的就是一个三目表达式,就不需要解释了

以上就是我对HashMap中的tableSizeFor(int cap)方法的理解,如果以上的解释不完整或者是出现错误的话,请各位大佬门评论区指正,我会及时更正的!

感谢观看!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值