首頁 > Java > java教程 > 主體

java中移位操作方法(<<、>>、>>>)

怪我咯
發布: 2017-06-30 10:31:08
原創
1903 人瀏覽過

下面小編就為大家帶來一篇java<<、>>、>>>移位操作方法。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟著小編過來看看吧

<<,有符號左移位,將運算數的二進位整體左移指定位數,低位用0補齊。

int leftShift = 10;
System.out.println("十进制:" + leftShift + ", 二进制:" + Integer.toBinaryString(leftShift));
int newLeftShift = letfShift << 2;
System.out.println("左移2位后十进制:" + newLeftShift + ", 左移2位后二进制" + Integer.toBinaryString(newLeftShift)); //正整数x左移n位后的十进制结果,x = x * 2^n
登入後複製

以上是正整數,運算結果如下。

接下來看看負數左移2位元運算是什麼情況,運算結果如下。

為什麼會-10的二進位會出現這麼多的1呢?仔細數一下剛好有32位。首先要了解的是Java負數儲存是以補碼形式儲存的(補碼=反碼+1),10的二進位是1010,它的反碼就是0101,再加1就是補碼0110。那為什麼會多出來那麼多1呢?這是因為int型在Java中佔8個字節,剛好32位,10原碼的高位全是0,它的反碼自然高位就變成了1。所以整體左移2位,低位以0補齊,最後的運算結果就是x = (|x| + 2^n)。

>>,有符號右移位,將運算數的二進位整體右移指定位數,整數高位用0補齊,負數高位用1補齊(保持負數符號不變)。


int rightShift = 10;
System.out.println("十进制:" + rightShift + ", 二进制:" + Integer.toBinaryString(rightShift));
int newRightShift = rightShift >> 2;
System.out.println("右移2位后十进制:" + newRightShift + ", 右移2位后二进制" + Integer.toBinaryString(newRightShift));  //右移n位后的运算数x十进制结果,x = x / 2
登入後複製


以上是正整數,運算結果如下。

接下來看看將負數進行右移2位元運算是什麼情況,運算結果如下。

負數的有符號右移基本原理還是和左移相同,不同的是結果的計算,因為這是有符號的右移,一直右移最後的結果就會是-1。歸納起來就是,如果運算數是偶數,那麼它的運算結果就是x = -(|x| / 2),如果運算數是奇數,那麼它的運算結果就是x = -(|x| / 2) - 1。

>>>,無符號右移位,不管正數還是負數,高位都用0補齊(忽略符號位)

先看正數,正數的>>>無符號右移位和>>有符號右移位計算結果相同

int rightShift = 10;
System.out.println("十进制:" + rightShift + ", 二进制:" + Integer.toBinaryString(rightShift));
int newRightShift = rightShift >>> 2;
System.out.println("右移2位后十进制:" + newRightShift + ", 右移2位后二进制" + Integer.toBinaryString(newRightShift));  //右移n位后的云算数x十进制结果,x = x / 2
登入後複製

以上是正整數,運算結果如下。

接下來看負整數,運算結果如下。

雖然無符號移位後的二進位和有符號移位後的二進位看起來相同的,但結果大相逕庭,記住有符號右移位操作,實際上是忽略符號的算術操作,即高位統一補0。

以上是java中移位操作方法(<<、>>、>>>)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!