Java編程那些事兒26—移位元運算符

來源:互聯網
上載者:User
 

Java編程那些事兒26—移位元運算符鄭州遊戲學院 陳躍峰出自:http://blog.csdn.net/mailbomb 4.5.2 移位元運算符         移位元運算符就是在二進位的基礎上對數字進行平移。按照平移的方向和填充數位規則分為三種:<<(左移)、>>(帶符號右移)和>>>(無符號右移)。         在移位元運算時,byte、short和char類型移位後的結果會變成int類型,對於byte、short、char和int進行移位時,規定實際移動的次數是移動次數和32的餘數,也就是移位33次和移位1次得到的結果相同。移動long型的數值時,規定實際移動的次數是移動次數和64的餘數,也就是移動66次和移動2次得到的結果相同。         三種移位元運算符的移動規則和使用如下所示:l << 運算規則:按二進位形式把所有的數字向左移動對應的位元,高位移出(捨棄),低位的空位補零。文法格式:  需要移位的數字 << 移位的次數例如: 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次方。l >> 運算規則:         按二進位形式把所有的數字向右移動對應位元,低位移出(捨棄),高位的空位補符號位,即正數補零,負數補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次方。l >>> 運算規則:         按二進位形式把所有的數字向右移動對應巍峨位元,低位移出(捨棄),高位的空位補零。對於正數來說和帶符號右移相同,對於負數來說不同。                   其他結構和>>相似。 4.5.3 小結         二進位運算子,包括位元運算符和移位元運算符,使程式員可以在二進位基礎上運算元字,可以更有效進行運算,並且可以以二進位的形式儲存和轉換資料,是實現網路通訊協定解析以及加密等演算法的基礎。         但是,在實際使用中,為了使代碼可讀性強,還是大量使用一般的算術運算子來進行數字運算。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.