一、java中有三種移位運算符
<< : 左移運算符,num << 1,相當于num乘以2
>> : 右移運算符,num >> 1,相當于num除以2
>>> : 無符號右移,忽略符號位,空位都以0補齊
在移位運算時,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次方。
>>>運算規則:按二進制形式把所有的數字向右移動對應巍峨位數,低位移出(舍棄),高位的空位補零。對于正數來說和帶符號右移相同,對于負數來說不同。
public class Test { public static void main(String[] args) { int number = 10; //原始數二進制 printInfo(number); number = number << 1; //左移一位 printInfo(number); number = number >> 1; //右移一位 printInfo(number); } /** * 輸出一個int的二進制數 * @param num */ private static void printInfo(int num){ System.out.println(Integer.toBinaryString(num)); } }
運行結果:
1010 10100 1010
對比:
43210 位數
-------- 1010 十進制:10 原始數 number 10100 十進制:20 左移一位 number = number << 1; 1010 十進制:10 右移一位 number = number >> 1;
文章列表