gpt4 book ai didi

java - ConcurrentHashMap 中位移运算符的使用

转载 作者:搜寻专家 更新时间:2023-10-31 20:18:15 24 4
gpt4 key购买 nike

在浏览 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 这样的常量可以直接声明,那么使用位移运算符有什么用。

最佳答案

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

位移位可以更容易地告知读者该值。在基数 10 中,它将表示 1073741824,这看起来像一个随机数。


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

int secondsInDay = 60 * 60 * 24;

我们表示一分钟的秒数,乘以一小时的分钟数,再乘以一天的小时数.

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

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

关于java - ConcurrentHashMap 中位移运算符的使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33829893/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com