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

arh*_*ham 5 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;
Run Code Online (Sandbox Code Playgroud)

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

Vin*_*igh 4

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

位移位可以更轻松地告知读者该值。以 10 为基数,它代表1073741824,这看起来像是一个随机数。


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

int secondsInDay = 60 * 60 * 24;
Run Code Online (Sandbox Code Playgroud)

我们用一分钟的秒数乘以一小时的分钟数再乘以一天的小时数来表示。

我们可以直接输入86400,但是如果我们想更改一小时中有多少分钟(代表其他星球上的时间)怎么办?您必须手动计算它才能更改该值。

另一方面,通过将其分解为如上所示的单位,我们可以简单地更改中间值60来更改一天中有多少分钟。