日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java 移位运算符的复合_Java移位运算符

發布時間:2024/8/1 java 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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移位运算符的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。