1.为什么hash表的默认长度为16?哈希表的容量一定要是2的整数次幂?
- HashMap中则通过h&(length-1)的方法来代替取模,实现了均匀的散列,效率也高很多。
- length为2的整数次幂的话,为偶数,这样length-1为奇数,奇数的最后一位是1,这样便保证了h&(length-1)的最后一位可能为0,也可能为1(这取决于h的值),即与后的结果可能为偶数,也可能为奇数,这样便可以保证散列的均匀性,而如果length为奇数的话,很明显length-1为偶数,它的最后一位是0,这样h&(length-1)的最后一位肯定为0,即只能为偶数,这样任何hash值都只会被散列到数组的偶数下标位置上,这便浪费了近一半的空间,因此,length取2的整数次幂,是为了使不同hash值发生碰撞的概率较小,这样就能使元素在哈希表中均匀地散列。
博客探讨了哈希表默认长度为16以及容量需为2的整数次幂的原因。在HashMap中用h&(length - 1)代替取模实现均匀散列。当length为2的整数次幂时,能保证散列均匀,减少不同hash值碰撞概率,避免空间浪费。
43万+

被折叠的 条评论
为什么被折叠?



