移位运算符,十进制不是特别直观,但用二进制,就要直观多了。
这里用正数和负数来玩
举个栗子
n = 5
它的二进制是:00000000000000000000000000000101 (总共32个数哦)
(1)n << 2,最左边移除2位,最右边补2个0,得到:00000000000000000000000000010100
(2)n >> 2,最右边移除2位,最左边补2个0,得到:00000000000000000000000000000001
(3)n>>>2,正数和 >> 是一样的。负数等会说。
当 n = -5
负数的二进制:先不看符号,把正数的 n 转为二进制 00000000000000000000000000000101
再进行反转,0的换成1,1的换成0,得到:11111111111111111111111111111010,再进行补码 +1
得到
11111111111111111111111111111011
就是 n = -5 的二进制
(1)n << 2,最左边移除2位,最右边补2个0,得到:11111111111111111111111111101100
(2)n >> 2,最右边移除2位,最左边补2个1,得到:11111111111111111111111111111110
(3)n >>> 2,最右边移除2位,最左边补2个0,得到:00111111111111111111111111111110