標籤:位元運算
/* * 位的運算 * */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中的位元運算