本文目錄一覽:
- 1、>,右移時左邊何時補0,何時補1′ title=’Java中,位運算符>>,右移時左邊何時補0,何時補1′>Java中,位運算符>>,右移時左邊何時補0,何時補1
- 2、java邏輯右移
- 3、java 無符號右移
- 4、Java 中 算術右移和邏輯右移有什麼區別
- 5、關於Java的算術右移運算符
>,右移時左邊何時補0,何時補1′>Java中,位運算符>>,右移時左邊何時補0,何時補1
在Thinking in Java第三章中的一段話:
移位運算符面向的運算對象也是二進位的「位」。可單獨用它們處理整數類型(主類型的一種)。左移位運算符()能將運算符左邊的運算對象向左移動運算符右側指定的位數(在低位補0)。「有符號」右移位運算符()則將運算符左邊的運算對象向右移動運算符右側指定的位數。「有符號」右移位運算符使用了「符號擴展」:若值為正,則在高位插入0;若值為負,則在高位插入1。Java也添加了一種「無符號」右移位運算符(),它使用了「零擴展」:無論正負,都在高位插入0。這一運算符是C或C++沒有的。
若對char,byte或者short進行移位處理,那麼在移位進行之前,它們會自動轉換成一個int。只有右側的5個低位才會用到。這樣可防止我們在一個int數里移動不切實際的位數。若對一個long值進行處理,最後得到的結果也是long。此時只會用到右側的6個低位,防止移動超過long值里現成的位數。但在進行「無符號」右移位時,也可能遇到一個問題。若對byte或short值進行右移位運算,得到的可能不是正確的結果(Java 1.0和Java 1.1特別突出)。它們會自動轉換成int類型,並進行右移位。但「零擴展」不會發生,所以在那些情況下會得到-1的結果。
java邏輯右移
2二進位表示為10,邏輯右移兩位即為0。
邏輯右移(),無論什麼時候都在左填0。而算術右移()則在左填符號位,符號位若為0則與邏輯右移結果一致,符號位為1則不一致。
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
Java 中 算術右移和邏輯右移有什麼區別
邏輯右移就是不用考慮最高位的符號位,只需要在移動之後的空位補0就行了,例如
初始數據:
1111
1111
右移一位:
0111
1111
最高位補0
算術右移則是要考慮符號位,如果最高位為1、則移動後在最高位補1、若最高位不為1,則移動後在最高位補0,例如
初始數據,最高位為1:
1111
1001
右移一位
1111
1100
初始數據,最高位不為1:
0111
1001
右移一位
0011
1100
關於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的補碼!
原創文章,作者:JTNT,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/135162.html