有趣的小算法

找到一个大于等于目标容量的最小的2的幂次方数,常用于实现具有动态扩展能力的数据结构。

示例:HashMap的扩容大小机制。

java 复制代码
static final int tableSizeFor(int cap) {
    int n = cap - 1;
    n |= n >>> 1;
    n |= n >>> 2;
    n |= n >>> 4;
    n |= n >>> 8;
    n |= n >>> 16;
    return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1;
}
  • a. 将n无符号右移一位。
  • b. 对原n和右移后的n进行按位或操作。
  • c. 将结果赋值回n。

这样做的目的是为了确保n的二进制表示中的所有非零位都被设置为1。这是因为每次右移一位后,原最高位会被移到次高位,并且按位或操作可以保证只要原来的最高位为1,那么新的次高位也将变为1。重复这个过程直到所有可能的位置都被覆盖到,从而得到大于等于目标容量的最小的2的幂次方数。

当cap = 25,最后返回32

相关推荐
WiChP7 小时前
【V0.1B5】从零开始的2D游戏引擎开发之路
java·服务器·数据库
cch89187 小时前
汇编与Java:底层与高层的编程对决
java·开发语言·汇编
荒川之神8 小时前
拉链表概念与基本设计
java·开发语言·数据库
cch89188 小时前
汇编与Go:底层到高层的编程差异
java·汇编·golang
workflower8 小时前
用硬件换时间”与“用算法降成本”之间的博弈
人工智能·算法·安全·集成测试·无人机·ai编程
chushiyunen8 小时前
python中的@Property和@Setter
java·开发语言·python
禾小西8 小时前
Java中使用正则表达式核心解析
java·python·正则表达式
yoyo_zzm8 小时前
JAVA (Springboot) i18n国际化语言配置
java·spring boot·python