java 的移位運算符

       移位運算符就是在二進制的基礎上對數字進行平移。按照平移的方向和填充數字的規則分爲三種:java

        <<(左移)、spa

        >>(帶符號右移)、code

        >>>(無符號右移)。
  在移位運算時,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次方。
  >>>運算規則:按二進制形式把全部的數字向右移動對應巍峨位數,低位移出(捨棄),高位的空位補零。對於正數來講和帶符號右移相同,對於負數來講不一樣。
  其餘結構和>>類似。class

package com.yuan.test;

public class MoveTest {
	public static void main(String[] args) {  
        System.out.println("******************正數左移在低位補0*******************");  
        int a = 1; 
        System.out.println("no move binary :"+Integer.toBinaryString(a));
        a = a << 2;  
        System.out.println("move binary <<2:"+Integer.toBinaryString(a));
        System.out.println("after move:"+a);
        
        System.out.println("******************正數右移在高位補0********************");  
        a = 1; 
        System.out.println("no move binary:"+Integer.toBinaryString(a)); 
        a = a >> 2;  
         
        System.out.println("move binary >>:"+Integer.toBinaryString(a)); 
        System.out.println("after move:"+a); 
        System.out.println("******從上面結果能夠看出:移位是不循環的*****");  
        System.out.println("看看負數的移位:");  
        System.out.println("***********負數的右移操做高位補1**************");  
        int i = -1;  
        System.out.println(i + ":");  
        System.out.println("no move binary:"+Integer.toBinaryString(i));  
        i = i >> 2;       
        System.out.println("move binary >>2:"+Integer.toBinaryString(i));  
        System.out.println("after move  >>2:"+i); 
        System.out.println("**********負數的左移操做低位補0*****************");  
        i = i << 2;  
        System.out.println(i);  
        System.out.println(Integer.toBinaryString(i));  
        System.out.println("*************再看看>>>操做符*************");  
        System.out.println("*************負數的>>>操做高位補0***************");  
        i = -1;  
        System.out.println(Integer.toBinaryString(i));  
        i = i >>> 10;  
        System.out.println(i + ":");  
        System.out.println(Integer.toBinaryString(i));  
        System.out.println("*************注意:沒有<<<符號**************");  
  
        System.out.println("**********byte類型移位時要強轉換*************");  
        byte k = 10;  
        System.out.println(Integer.toBinaryString(k));  
        k = (byte) ((byte) k >>> 2);  
        System.out.println(Integer.toBinaryString(k));  
    }  

}
相關文章
相關標籤/搜索