为什么(-1 >>> 32)= -1?

-1作为转换为二进制的int表示为321。当我右移31次时,得到1(31个0和一个1)。但是当我右移32次时,我又得到-1。它不应该等于0吗?

回答:

Java规范对移位运算符的解释如下:

如果左侧操作数的提升类型为int,则仅将右侧操作数的最低5位用作移位距离。就像右手操作数受到掩码值的按位逻辑AND运算符&(第15.22.1节)一样0x1f。因此,实际使用的移动距离始终在0到31(含)范围内。

的值32 & 0x1f为零。

如果左侧操作数为long,则您会为右侧操作数获得一个额外的位,将上限扩展为63而不是31。


为了具有从-1向右移动的任何特定期望值,您需要指定整数的基本二进制表示形式(例如,二进制补码)以及位数(例如,32)。每种编程语言都可以不同地定义它们,但是为了使实现更简单,通常会指定不允许移位超过可用位数。这通常是因为基础CPU硬件也不支持它。毕竟,如果要移位那么多位,则左操作数不再重要,因为结果将始终相同。

以上是 为什么(-1 >>> 32)= -1? 的全部内容, 来源链接: utcz.com/qa/421656.html

回到顶部