HashMap如何处理自定义大小为非2的幂次方:tableSizeFor(int i)

先上源码:

static final int tableSizeFor(int i) {//i为自定义容器的大小
	int j = i - 1;
	j |= j >>> 1;
	j |= j >>> 2;
	j |= j >>> 4;
	j |= j >>> 8;
	j |= j >>> 16;
	return j >= 0 ? j < MAXIMUM_CAPACITY? j + 1 : MAXIMUM_CAPACITY: 1;
}

这段代码的作用是将一个非负整数(自定义大小)转换成第一个大于等于它本身的 2 的幂次方的数。

例如,设置大小为 9,则经过计算得到 16。
基本思路:二进制下低位全部转换成 1,再加一,大小为 9 的时候,00001001,要得到 00001111,再加一得到 00010000,即 16。

具体计算过程如下:
第一步:j |= j >>> 1;
00001000 >>> 1 ==> 00000100
00001000 | 00000100 ==> 00001100

第二步:j |= j >>> 2;
00001100 >>> 2 ==> 00000011
00001100 | 00000011 ==> 00001111

第三步、第四步同样。

原理:
利用非负整数第一位二进制为 1 的特点,结合左移和或运算,将原数据低位转换成 1。

细节:

  1. 算法开头需要将原始大小减一,目的是考虑原始大小为 2 的幂次方时,得到结果还是其本身。
  2. 返回值:必须为非负整数,否则返回 1,若超过最大值,则返回最大值(int 能存储的最大值)
  3. 为什么左移 16 位就计算结束了?因为 int 类型数据占 32 位,前 4 步将高 16 位转换成 1,最后一步将低 16 位转换成 1。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值