首先,数据在计算机中是以补码的形式存储的。对于正数而言,原码、反码、补码形式一致;对于负数而言,反码就是原码中所有1变成0,0变成1,补码就是在反码的基础上加1所得。
然后:
>>:带符号右移,正数右移高位补0,负数右移高位补1;
>>>:无符号右移,不管是正数还是负数,右移高位补0。
例子:
n = 8
原码:0000 0000 0000 0000 0000 0000 0000 1000
反码:0000 0000 0000 0000 0000 0000 0000 1000
补码:0000 0000 0000 0000 0000 0000 0000 1000
n>>1
补码:0000 0000 0000 0000 0000 0000 0000 0100
n>>>1
补码:0000 0000 0000 0000 0000 0000 0000 0100
n = -8
原码:1000 0000 0000 0000 0000 0000 0000 1000
反码:1111 1111 1111 1111 1111 1111 1111 0111
补码:1111 1111 1111 1111 1111 1111 1111 1000
n>>1
补码:1111 1111 1111 1111 1111 1111 1111 1100
n>>>1
补码:0111 1111 1111 1111 1111 1111 1111 1100
其值为:2147483644