HashMap初始化大小计算源码
//计算大于cap的最小2的n方
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;
}
原理解析
Hash 值的范围值-2147483648 到 2147483647,前后加起来大概 40 亿的映射空间,只要哈希函数映射得比较均匀松散,一般应用是很难出现碰撞的。但问题是一个 40 亿长度的数组,内存是放不下的。所以HashMap的底层设计,采用%取余的操作来实现。
取余(%)操作中如果除数是 2 的幂次则等价于与其除数减一的与(&)操作(也就是说 hash%length==hash&(length-1)的前提是 length 是 2 的 n 次方;并且采用二进制位操作 &,相对于%能够提高运算效率,这就解释了 HashMap 的长度为什么是 2 的幂次方。
HashMap初始化大小计算原理解析
博客围绕HashMap初始化大小计算源码展开原理解析。指出Hash值映射空间大,但40亿长度数组内存放不下,所以HashMap底层用%取余操作。还说明取余时若除数是2的幂次,与除数减一的与操作等价,且位操作能提高效率,解释了其长度为2的幂次方原因。
1113






