<< :左移運算符,n<<1至關於 n*2
>> :右移運算符,n>>1相等於n/2
>>>:無符號右移,忽略
int a=-1;
-1的32進制位:
源碼 : 0000 0000 0000 0000 0000 0000 0000 0001
反碼 : 1111 1111 1111 1111 1111 1111 1111 1110
補碼 : 1111 1111 1111 1111 1111 1111 1111 1111 (在反碼基礎上+1)
a<<2: 1111 1111 1111 1111 1111 1111 1111 1100
a>>2: 1111 1111 1111 1111 1111 1111 1111 1111 (右移兩位,左邊高位再補兩個1,因此看着沒什麼變化)
a>>>2: 0011 1111 1111 1111 1111 1111 1111 1111 (無符號右移跟上個比起來就是高位不補1)
上面-1 >>2看着沒什麼變化能夠換成-5 試試:
int a=-5;
System.out.println(Integer.toBinaryString(a));
System.out.println(Integer.toBinaryString(a>>2));
System.out.println(a>>2);
11111111111111111111111111111011
11111111111111111111111111111110
-2
-------------------------------------------------------
int a=-5;
System.out.println(Integer.toBinaryString(a));
System.out.println(Integer.toBinaryString(a>>>2));
System.out.println(a>>>2);
11111111111111111111111111111011
111111111111111111111111111110
1073741822