Java中的位元運算

來源:互聯網
上載者:User

標籤:位元運算

/* * 位的運算 * */public class Operator {public static void main(String[] args) {/* * 右移操作>>有符號  正數補0 負數補1 *   >>>無符號正數補0 負數補1 */int a = 10 ;//轉換成二進位,往後挪動2位前面補0,最後兩位抹去System.out.println(a>>2);//移動一位相當於處於2System.out.println(Integer.toBinaryString(a>>2));//無符號移位System.out.println(a>>>2);System.out.println(Integer.toBinaryString(a>>>2));int b = -10 ;//前面補位 補1 後面抹去/* * 推理過程 * a.先得到-10的二進位 * 10的二進位 28個01010 *  取反 28個10101---》+1 * -10的二進位 28個10110 * b.移動 1128個1 01 這個就是最終的負數 * 右移動兩位 * c.計算最後結果 * 負數取反+1得到對應的正數 * 0028個010 +1------》得到對應的正數00 28個011 * 正數3對應的負數是-3 */System.out.println(b>>2);//無符號右移動專門針對負數 負數在前面也是補0System.out.println(b>>>2);/* * 左移動操作<<後面補0(不管正負數) */System.out.println(a<<2);//左移動一位,乘以2System.out.println(b<<2);}}& (位與)、|(位或)、^(異或)package com.pb.polyTest;public class Operator2 {public static void main(String[] args) {int c1 = 5;int d1 = 4;/* * 把兩個數字都轉換為十進位然後一位位的計算 * 都是1這一位就為1,否則為0得到的二進位再轉換為十進位 */System.out.println(c1 & d1);/* * 把兩個數字都轉換為十進位然後一位位的計算 * 都是0這一位就為0,否則為1得到的二進位再轉換為十進位 */System.out.println(c1 | d1);/* * 把兩個數字都轉換為十進位然後一位位的計算 * 相同為0不同為1得到的二進位再轉換為十進位 */System.out.println(c1 ^ d1);/* * 如果c =a ^ b ; * 那麼a == c ^ b ; * b == a ^ c ; */}}


本文出自 “java” 部落格,請務必保留此出處http://5737386.blog.51cto.com/5727386/1661079

Java中的位元運算

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.