Java中的<< 和 >> 和 >>> 分析理解


Java中的<< 和 >> 和 >>> 詳細分析

<<表示左移移,不分正負數,低位補0;

注:以下數據類型默認為byte-8位

左移時不管正負,低位補0

正數:r = 20 << 2

  20的二進制補碼:0001 0100

  向左移動兩位后:0101 0000

       結果:r = 80

負數:r = -20 << 2

  -20 的二進制原碼 :1001 0100

  -20 的二進制反碼 :1110 1011

  -20 的二進制補碼 :1110 1100

  左移兩位后的補碼:1011 0000

        反碼:1010 1111

        原碼:1101 0000

        結果:r = -80

>>表示右移,如果該數為正,則高位補0,若為負數,則高位補1;

注:以下數據類型默認為byte-8位

正數:r = 20 >> 2

  20的二進制補碼:0001 0100

  向右移動兩位后:0000 0101

       結果:r = 5

負數:r = -20 >> 2

  -20 的二進制原碼 :1001 0100

  -20 的二進制反碼 :1110 1011

  -20 的二進制補碼 :1110 1100

  右移兩位后的補碼:1111 1011

        反碼:1111 1010

        原碼:1000 0101

        結果:r = -5

>>>表示無符號右移,也叫邏輯右移,即若該數為正,則高位補0,而若該數為負數,則右移后高位同樣補0

正數: r = 20 >>> 2

    的結果與 r = 20 >> 2 相同;

負數: r = -20 >>> 2

注:以下數據類型默認為int 32位

  -20:源碼:10000000 00000000 00000000 00010100

    反碼:11111111 11111111 11111111 11101011

    補碼:11111111 11111111 11111111 11101100(在反碼基礎上加1)

    右移:00111111 11111111 11111111 11111011

    結果:r = 1073741819

總結(數學意義):
  1. 2 >> 1 = 1即左邊數除以2的1次方,右移n位就除以2的n次方(二進制右移肯定變小);

  2. 2 << 1 = 4即左邊數乘以2的1次方,左移n位就乘以2的n次方(二進制左移肯定變大);

  3. 2 >>> 1 = 1 正數無符號右移等於右移;

在移位運算時,byte、short和char類型移位后的結果會變成int類型,對於byte、short、char和int進行移位時,規定實際移動的次數是移動次數和32的余數,也就是移位33次和移位1次得到的結果相同。移動long型的數值時,規定實際移動的次數是移動次數和64的余數,也就是移動66次和移動2次得到的結果相同。

參考:

http://www.imooc.com/wenda/detail/426292

https://www.cnblogs.com/chuijingjing/p/9405598.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM