在ConcurrentHashMap中使用位智能移位运算符

时间:2015-11-20 15:05:32

标签: java bit-shift concurrenthashmap

当我浏览ConcurrentHashMap源代码时,我遇到了很多位智能移位运算符。一些应用于创建常量,一些用于变量。

static final int MAXIMUM_CAPACITY = 1 << 30;
static final int MAX_SEGMENTS = 1 << 16; // slightly conservative
long u = (((h >>> segmentShift) & segmentMask) << SSHIFT) + SBASE;

我无法理解,如果可以直接声明MAXIMUM_CAPACITY之类的常量,那么使用按位移位运算符有什么用。

1 个答案:

答案 0 :(得分:3)

他们没有使用十进制形式的数字(基数为10)。相反,他们说&#34; 这是一个30个尾随0位的数字&#34;,暗示该数字用于基础2系统。

比特移位使得更容易告知读者价值。在基数10中,它代表1073741824,它看起来像一个随机数。

这在编程中很常见。例如:

int secondsInDay = 60 * 60 * 24;

我们代表一分钟内的秒数,再乘以一小时内的分钟数,再乘以一天中的小时数

我们可以放86400,但如果我们想改变一小时内的分钟数(代表其他星球上的时间)怎么办?您必须手动计算它才能更改值。

另一方面,通过将其分解为如上所示的单位,我们只需更改中间60即可更改一天中的分钟数。