计算机表达数值是一个固定长度的二进制串,一般的计算机位32位或64位,这个固定位数的最高位表示符号位,为1表示负数,为0表示正数。
- ‘<<’ 左移
向左移动对应的位数,向左移出的位被丢弃,右侧用零补齐。
例如:9 << 2 ,得到36
9 (base 10): 00000000000000000000000000001001 (base 2)
--------------------------------
9 << 2 (base 10): 00000000000000000000000000100100 (base 2) = 36 (base 10)
- ‘>>’ 有符号右移
向右移动对应的位数,向右移出的位被丢弃,拷贝最左侧的位以填充左侧,即正数左侧用0补齐,负数左侧用1补齐。
例如:9 >> 2 ,得到2
9 (base 10): 00000000000000000000000000001001 (base 2)
--------------------------------
9 >> 2 (base 10): 00000000000000000000000000000010 (base 2) = 2 (base 10)
相比,-9 >> 2 ,得到-3,因为符号位被保留了。
-9 (base 10): 11111111111111111111111111110111 (base 2)
--------------------------------
-9 >> 2 (base 10): 11111111111111111111111111111101 (base 2) = -3 (base 10)
- ‘>>>’ 无符号右移
向右移动对应的位数,向右移出的位被丢弃,左侧用0补齐。因为最左侧符号位一定是0,所以结果一定是非负的(即使移动0位,结果也是非负的)。
对于非负数,有符号右移和无符号右移都是一样的,例如:9 >>> 2,也返回2
9 (base 10): 00000000000000000000000000001001 (base 2)
--------------------------------
9 >>> 2 (base 10): 00000000000000000000000000000010 (base 2) = 2 (base 10)
但是对于负数却不一样,例如:-9 >>> 2,得到1073741821
-9 (base 10): 11111111111111111111111111110111 (base 2)
--------------------------------
-9 >>> 2 (base 10): 00111111111111111111111111111101 (base 2) = 1073741821 (base 10)