444444444>>>-5=3搞不懂原理

444444444>>>-5=3
請問這個是什麽意思?
不明白-5表示什麽? 正數的話我就懂...

3个回答

在官网文档http://docs.oracle.com/javase/specs/jls/se7/html/jls-15.html#jls-15.19
有如下一段话:
[quote]
If the promoted type of the left-hand operand is int, only the five lowest-order bits of the right-hand operand are used as the shift distance. It is as if the right-hand operand were subjected to a bitwise logical AND operator & (§15.22.1) with the mask value 0x1f (0b11111). The shift distance actually used is therefore always in the range 0 to 31, inclusive.

If the promoted type of the left-hand operand is long, then only the six lowest-order bits of the right-hand operand are used as the shift distance. It is as if the right-hand operand were subjected to a bitwise logical AND operator & (§15.22.1) with the mask value 0x3f (0b111111). The shift distance actually used is therefore always in the range 0 to 63, inclusive.
[/quote]

看来之前我说的mod方式有些不是很合理,以官网说的为准,他描述了左操作符如果是int则只取移位表达式补码的最后5位
如果是long则只取移位表达式补码的最后6位

iteye_12441
iteye_12441 对了,3ks
7 年多之前 回复
iteye_171
iteye_171 这里是移动27位啊,,哪里移动30位了? 11010011111011010111100011100也才29位啊。。。移动了27位,剩下11,不就是=3么?
7 年多之前 回复
iteye_12441
iteye_12441 按照你所说的理论,有些情况是符合的,有些情况则不对. -----------------------------------------这是分割线-------------------------------------------- 符合的例子 444444444>>>-31=222222222 也就是 11010011111011010111100011100>>>11111111111111111111111111100001=1101001111101101011110001110 取后面5位,也就是 11010011111011010111100011100>>>00001(10进制1)=1101001111101101011110001110 移动1位,结果正确 -----------------------------------------这是分割线-------------------------------------------- 不符合的例子: 444444444>>>-5=3 也就是 11010011111011010111100011100>>>11111111111111111111111111111011=11 按照你所说,取后面5位,也就是 11010011111011010111100011100>>>11011(10进制27)=11 这里就不对了,这里实际上是移动了30位,而不是27位 希望大大再补充资料,把这个问题,帮我弄清楚
7 年多之前 回复

1、-5在计算机中保存的时候是补码方式即
二进制1111 1111 1111 1111 1111 1111 1111 1101

2、java中的<<, >>, >>>移位是周期以为

比如1>>>32 相当于有移位还是=1
他是这样的x >>> (y mod 32)

3、根据上面公式444444444 >>> (二进制1111 1111 1111 1111 1111 1111 1111 1101 mod 32)

等价于 444444444 >>> 二进制11101
等价于 444444444 >>> 27
等于 3

1、-5在计算机中保存的时候是补码方式即
二进制1111 1111 1111 1111 1111 1111 1111 1101

2、java中的<<, >>, >>>移位是周期移位

比如1>>>32 相当于没有移位
他是有这样公式: x >>> (y mod 32)

3、根据上面公式444444444 >>> (二进制1111 1111 1111 1111 1111 1111 1111 1101 mod 32)

等价于 444444444 >>> 二进制11101
等价于 444444444 >>> 27
等于 3

iteye_171
iteye_171 补充一点,mod多少,根据y情况。如果是long那就是64了,而不是32
7 年多之前 回复
立即提问