您好,登錄后才能下訂單哦!
如何在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中使用<<、>>進行移位操作問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。