Java 移位运算符的复合_Java移位运算符
移位運算符就是在二進制的基礎上對數字進行平移。按照平移的方向和填充數字的規則分為三種:<>(帶符號右移)和>>>(無符號右移)。
在移位運算時,byte、short和char類型移位后的結果會變成int類型,對于byte、short、char和int進行移位時,規定實際移動的次數是移動次數和32的余數,也就是移位33次和移位1次得到的結果相同。移動long型的數值時,規定實際移動的次數是移動次數和64的余數,也就是移動66次和移動2次得到的結果相同。
三種移位運算符的移動規則和使用如下所示: <
語法格式: 需要移位的數字 << 移位的次數
例如: 3 << 2,則是將數字3左移2位
計算過程: 3 << 2
首先把3轉換為二進制數字0000 0000 0000 0000 0000 0000 0000 0011,然后把該數字高位(左側)的兩個零移出,其他的數字都朝左平移2位,最后在低位(右側)的兩個空位補零。則得到的最終結果是0000 0000 0000 0000 0000 0000 0000 1100,則轉換為十進制是12.數學意義:
在數字沒有溢出的前提下,對于正數和負數,左移一位都相當于乘以2的1次方,左移n位就相當于乘以2的n次方。
>>運算規則:按二進制形式把所有的數字向右移動對應巍峨位數,低位移出(舍棄),高位的空位補符號位,即正數補零,負數補1.
語法格式: 需要移位的數字 >> 移位的次數
例如11 >> 2,則是將數字11右移2位
計算過程:11的二進制形式為:0000 0000 0000 0000 0000 0000 0000 1011,然后把低位的最后兩個數字移出,因為該數字是正數,所以在高位補零。則得到的最終結果是0000 0000 0000 0000 0000 0000 0000 0010.轉換為十進制是3.數學意義:右移一位相當于除2,右移n位相當于除以2的n次方。
>>>運算規則:按二進制形式把所有的數字向右移動對應巍峨位數,低位移出(舍棄),高位的空位補零。對于正數來說和帶符號右移相同,對于負數來說不同。
其他結構和>>相似。
小結
二進制運算符,包括位運算符和移位運算符,使程序員可以在二進制基礎上操作數字,可以更有效的進行運算,并且可以以二進制的形式存儲和轉換數據,是實現網絡協議解析以及加密等算法的基礎。
實例操作: public class URShift {
public static void main(String[] args) {
int i = -1;
i >>>= 10;
//System.out.println(i);
mTest();
}
public static void mTest(){
//左移
int i = 12; //二進制為:0000000000000000000000000001100
i <<= 2; //i左移2位,把高位的兩位數字(左側開始)拋棄,低位的空位補0,二進制碼就為0000000000000000000000000110000
System.out.println(i); //二進制110000值為48;
System.out.println("
");
//右移
i >>=2; //i右移2為,把低位的兩個數字(右側開始)拋棄,高位整數補0,負數補1,二進制碼就為0000000000000000000000000001100
System.out.println(i); //二進制碼為1100值為12
System.out.println("
");
//右移example
int j = 11;//二進制碼為00000000000000000000000000001011
j >>= 2; //右移兩位,拋棄最后兩位,整數補0,二進制碼為:00000000000000000000000000000010
System.out.println(j); //二進制碼為10值為2
System.out.println("
");
byte k = -2; //轉為int,二進制碼為:0000000000000000000000000000010
k >>= 2; //右移2位,拋棄最后2位,負數補1,二進制嗎為:11000000000000000000000000000
System.out.println(j); //二進制嗎為11值為2
}
}
在Thinking in Java第三章中的一段話:
移位運算符面向的運算對象也是
二進制的“位”。 可單獨用它們處理整數類型(主類型的一種)。左移位運算符(<>)則將運算符左邊的運算對象向右移動運算符右側指定的位數。“有符號”右移位運算符使用了“符號擴展”:若值為正,則在高位插入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 移位运算符的复合_Java移位运算符的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: window10配置OpenGL ES3
- 下一篇: 这个1500个+Javascript特效