use*_*037 12 java bit-manipulation bit-shift
可能重复:
为什么1 >> 32 == 1?
-1作为转换为二进制的int由32 1表示.当我右移31次时,我得到1(31 0和1).但当我右移32次时,我再次得到-1.它不应该等于0吗?
Rob*_*edy 18
Java规范解释了移位运算符如下:
如果左手操作数的提升类型是
int,则只使用右手操作数的五个最低位作为移位距离.就好像右手操作数受到带掩码值的按位逻辑AND运算符&(第15.22.1节)的影响0x1f.因此,实际使用的移位距离始终在0到31的范围内,包括0和31.
值32 & 0x1f为零.
如果左操作数是long,则为右操作数获取额外的位,将上限扩展为63而不是31.
为了从-1向右移动具有任何特定的期望值,您需要指定整数的基础二进制表示(例如,二进制补码)以及位数(例如,32).每种编程语言都可以不同地定义它们,但为了使实现更简单,它们通常会指定不允许移位超过可用位数.这通常是因为底层CPU硬件也不支持它.毕竟,如果要移动那么多位,左操作数不再重要,因为结果总是相同的.
| 归档时间: |
|
| 查看次数: |
2461 次 |
| 最近记录: |