有趣的小算法

找到一个大于等于目标容量的最小的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

相关推荐
最初的↘那颗心3 分钟前
Java HashMap深度解析:原理、实现与最佳实践
java·开发语言·面试·hashmap·八股文
小兔兔吃萝卜10 分钟前
Spring 创建 Bean 的 8 种主要方式
java·后端·spring
pusue_the_sun25 分钟前
数据结构——栈和队列oj练习
c语言·数据结构·算法··队列
大锦终26 分钟前
【算法】模拟专题
c++·算法
亲爱的马哥32 分钟前
重磅更新 | 填鸭表单TDuckX2.9发布!
java
Java中文社群33 分钟前
26届双非上岸记!快手之战~
java·后端·面试
whitepure38 分钟前
万字详解Java中的面向对象(二)——设计模式
java·设计模式
whitepure40 分钟前
万字详解Java中的面向对象(一)——设计原则
java·后端
Xの哲學1 小时前
Perf使用详解
linux·网络·网络协议·算法·架构
2301_793086871 小时前
SpringCloud 02 服务治理 Nacos
java·spring boot·spring cloud