一、<<
<<表示左移,不分正负,低位补0
1.正数的左移
注:以下数据类型默认为byte-8位
r = 20 << 2
20的二进制: 0001 0100
左移2位: 0101 0000
结果: r=80
2.负数的左移
注:以下数据类型默认为byte-8位
r = -20 << 2
-20 的二进制原码 :1001 0100 //首位1代表是负数
-20 的二进制反码 :1110 1011 //除了首位,其他反转
-20 的二进制补码 :1110 1100 //补码 = 反码 + 1
左移两位后的补码:1011 0000
反码:1010 1111
原码:1101 0000
结果:r = -80
二、>>
>>表示右移,如果该数为正,则高位补0,若为负数,则高位补1
1.正数的右移
注:以下数据类型默认为byte-8位
r = 20 >> 2
20的二进制补码: 0001 0100
向右移动两位后: 0000 0101
结果:r = 5
2.负数的右移
注:以下数据类型默认为byte-8位
r = -20 >> 2
-20 的二进制原码 : 1001 0100
-20 的二进制反码 : 1110 1011
-20 的二进制补码 : 1110 1100
右移两位后的补码: 1111 1011
反码: 1111 1010
原码: 1000 0101
结果:r = -5
三、>>>
>>>表示无符号右移,也叫逻辑右移,即若该数为正,则高位补0,而若该数为负数,则右移后高位同样补0
1.正数的无符号右移
r = 20 >>> 2的结果与 r = 20 >> 2 相同。
2.负数的无符号右移
注:以下数据类型默认为int 32位
r = -20 >>> 2
-20:源码: 10000000 00000000 00000000 00010100
反码: 11111111 11111111 11111111 11101011
补码: 11111111 11111111 11111111 11101100
右移: 00111111 11111111 11111111 11111011
结果: r = 1073741819