代码示例:
乍一看到这个方法还是有点蒙的,这是要干啥
n |= n >>> 1;
- 分开看
n >>> 1
这里可以理解,是将n进行右移一位
举个例子:如果n = 64 那么进行n >>> 1
的操作后n的值变成了32 - 再看
n |= a
这里的意思就是就是n和a两个值进行按位或操作,然后将值复制给n,可以把它大概理解成n+=a
- 这里就可以大概理解上面的一串代码是干什么的了,这段代码的意思就是将n的二进制数所有的0变成1
- 看完最蒙的一段代码后,剩下的就比较好解释了
cap - 1
的意思就是防止cap本身就是2的整数次幂,经过后面一段代码后变成2的n+1次幂。 - 最后return的就是一个三目表达式,就不需要解释了
以上就是我对HashMap中的tableSizeFor(int cap)方法的理解,如果以上的解释不完整或者是出现错误的话,请各位大佬门评论区指正,我会及时更正的!
感谢观看!