>>
是指有符号位移。 (简单理解就是区分一个数字的正负在进行移动)。
>>>
是指无符号位移。 (简答理机就是会无视一个数字是正数还是负数,进行统一规则的运算)。
10 的 二进制是 1010 10 >> 1 // 5 10 >>> 1 // 5
10 的二进制是 1010,所以向右移动一位,就是 101,右边移动一位,所以为了补全 32 位(四个字节),就需要参照,正数前面补充 0,负数补充 1 的规则,然后十进制表示就是 5,0000..000(29 个零)101。
正数以二进制容易表示,负数在计算机中是以(补码 = 反码 + 1)。
-10 用补码表示
二进制 000…000(28 个 0)1010
反码 111…111(28 个 1)0101
补码 111…111(28 个 1)0110
-10 >> 1
有符号位移的话,
右边移去了一个 0,111…111(28 个 1)011,
前面补 1,得到 111…111(29 个 1)011
在存放整数的存储单元中,最左面的一位是符号位:该位为 0,表示数值为正;该位为 1,表示数值为负。
所以我们继续求回原码。第一位是 “0” 的是正数,正数的原码就是补码。如果补码的符号位为“1”,表示该数是一个负数,那么对给定的这个补码再求补码,就是要求的原码。
我们上面求补码的方法是先取反在+1,现在我们继续对上面求的补码进行取反。
第一位的 0 表示该数是一个负数,所以不变更符号位,该位仍为“1”。
对除符号位以外的数值位取反,结果为 1000…000(28 个 0)100。
对上面的取反后的值 + 1,得到 1000…000(28 个 0)101。
我们将除去第一位的 1, 然后其他位 000…000(28 个 0)101 求十进制,得到 5,加上第一位的符号位,得到 -5。
-10 >>> 1
无符号位移的话,
右边去掉一个 0,111…111(28 个 1)011,
左边补充一个 0(无视正,负),0111…111(28 个 1)011,
然后正数的十进制表示出来 0111..111(28 个 1)011 十进制变成 2147483643。