java右移
1. java左移和右移有什麼用
左移和右移並不常用,在一些特殊情況下才會使用,比如加解密時,會大量用到。
另外,偶爾在優化少數特殊代碼的速度時可能用到,例如x*4就可以x<<2來代替,而後者比前者的速度快了好多倍。
2. java邏輯右移
2二進製表示為10,邏輯右移兩位即為0。
邏輯右移(>>>),無論什麼時候都在左填0。而算術右移(>>)則在左填符號位,符號位若為0則與邏輯右移結果一致,符號位為1則不一致。
3. java的右移和無符號右移 (新手)
>>>是邏輯右移,前面是補1而不是補0。輸出時也要轉換為原碼。
4. java 無符號的右移怎麼解釋
>>是帶符號右移
>>>才是無符號右移..
帶符號右移就是將那個數轉為2進制然後在前面補0或1
如果是正數就補0
負數補1
例如11 >> 2,則是將數字11右移2位
計算過程:
11的二進制形式為:0000 0000 0000 0000 0000 0000 0000 1011,然後把低位的最後兩個數字移出,因為該數字是正數,所以在高位補零。則得到的最終結果是0000 0000 0000 0000 0000 0000 0000 0010。轉換為十進制是2。
無符號右移與帶符號右移的區別就是 無符號始終補0
5. java 右移
java中貌似一般都用byte存二進制,八進制和十六進制倒是能在數字前加0和0x表示,二進制沒有。
定義一個int型變數,系統默認為十進制的。
你現在想把一個數右移,具體的處理方法要根據你的這個「數」是個什麼類型的。
如果是字元串,可以用以下方法處理:
String s = "101";
int i = Integer.parseInt(s, 2);
這樣得到的i就是5,再右移的話就沒問題了。
如果是數字,可以根據具體的進制進行相關轉換操作,如果轉成byte[]不方便可以轉成八進制或十六進制。主要看你要右移的是個什麼類型的了。
具體的可以給我留言~:)
6. Java 中 算術右移和邏輯右移有什麼區別
邏輯右移就是不用考慮最高位的符號位,只需要在移動之後的空位補0就行了,例如
初始數據:
1111
1111
右移一位:
0111
1111
最高位補0
算術右移則是要考慮符號位,如果最高位為1、則移動後在最高位補1、若最高位不為1,則移動後在最高位補0,例如
初始數據,最高位為1:
1111
1001
右移一位
1111
1100
初始數據,最高位不為1:
0111
1001
右移一位
0011
1100
7. Java中右移與無符號右移書上沒解釋
右移:第一個操作數的二進制位按第二個操作說的大小向右移位,左端用符號位補位:
int a=5; a>>2,表示a化為二進制然後右移2位,左端補0、
無符號右移,就是不管最高位是什麼,左端一律補0
8. java中右移運算符和無符號右移運算符的區別
舉個例子 int a =7>>1 , 就是將7的二進制(111)向右移動一位,就是(011)就是3,所以int a=3;
也可看成是除以二,如果左操作數是奇數就看做(a-1)÷2,是偶數就是 a÷
2
右移位運算就是將左操作數的比特位向右移動第二個操作數指定的位數,在二進制中,首位是用來表示正負的,若右移運算符的第一個操作數是正數,就填充0,是負數就填充1;
9. Java中右移運算
將一個數的各二進制位全部右移若干位,正數左補0,負數左補1,右邊丟棄。
操作數每右移一位,相當於該數除以2。
註:正數的原碼,反碼,補碼一致;負數的反碼是除去符號位外其餘取反,負數補碼是除去符號位外其餘取反,末尾加1。 (二進制最左邊一位是符號位)
帶符號右移運算符(>>)
將一個數的各二進制位全部右移若干位,正數左補0,負數左補1,右邊丟棄。
無符號右移運算符(>>>)
>>>運算符把 expression1 的各個位向右移 expression2 指定的位數。右移後左邊空出的位用零來填充。移出右邊的位被丟棄
-1>>2 = -1
-1: 原碼:1000 0001 反碼:1111 1110 補碼:1111 1111
右移2位:1111 1111 ( 用補碼操作,並用 1 補齊左邊位)
再找反碼:1000 0000 ( 除去左邊符號位,其餘取反 )
再找原碼:1000 0001 = -1 ( 還是將反碼末尾加1 )
-5>>2=-2
-5: 原碼:1000 0101 反碼:1111 1010 補碼:1111 1011
右移2位:1111 1110 ( 用補碼操作,並用 1 補齊左邊位)
再找反碼:1000 0001 ( 除去左邊符號位,其餘取反 )
再找原碼:1000 0010 = -2 ( 還是將反碼末尾加1 )
-5>>>2=1073741822
-5:
原碼:1111 1111 1111 1111 1111 1111 1111 0101
反碼:1111 1111 1111 1111 1111 1111 1111 1010
補碼:1111 1111 1111 1111 1111 1111 1111 1011
右移2位:0011 1111 1111 1111 1111 1111 1111 1110=1073741822
10. 關於Java的算術右移運算符
你說的右移應該是整數除法裡面提到的吧。
整數除法總是zero-round,即商總是向靠近0的數方向進行舍入。
因為要向0靠近,所以負數在除2的冪之前會先加上一個偏移量2的k次方減1(2k-1,k為右移的位數)以修正
假設8位有符號表示:
則-5的補碼為 1111 1011
右移一位: 1111 1101
上面的結果是-3的補碼,和實際不符(-5/2 = -2)
加上修正值: 1111 1011 + 2的一次方減1 = 1111 1011 + 1 = 1111 1100
然後再右移一位:1111 1110 <= -2的補碼!