Java位運算子範例

2019-10-16 22:21:23

Java定義了幾個按位元運算子,可以應用於整數型別, 如:longintshortcharbyte。按位元運算子處理位並執行逐位運算。 假設a = 60b = 13; 採用二進位制格式,它們將如下 -

a = 0011 1100

b = 0000 1101

-----------------

a&b = 0000 1100

a|b = 0011 1101

a^b = 0011 0001

~a  = 1100 0011

下面的表中列出了按位元運算子,假設整數變數A=60,變數B=13,那麼 -

運算子 描述 範例
& 二進位制AND運算子,如果存在於兩個運算元中,則它會將結果複製到結果中。 A & B的結果為:12,也就是:0000 1100
Ι 二進位制OR運算子,如果存在於任一運算元中,則複製一位。 A Ι B 的結果為:61,也就是:0011 1101
^ 二進位制互斥或運算子,如果在一個運算元中設定但不在兩個運算元中設定,則複製該位。 A ^ B的結果為:49,也就是:0011 0001
~ 二元一元補充運算子是一元的,具有「翻轉」位的效果。 ~A的結果為:-61,也就是:1100 0011
<< 二進位制左移運算子,左運算元值向左移動右運算元指定的位數。 A << 2的結果為:240,也就是:1111 0000
>> 二進位制右移運算子,左運算元值向右移動右運算元指定的位數。 A >> 2的結果為:15,也就是:1111
>>> 右移零填充運算子。 左運算元值向右移動右運算元指定的位數,移位值用零填充。 A >>>2的結果為:15,也就是:0000 1111
public class Test {

   public static void main(String args[]) {
      int a = 60;    /* 60 = 0011 1100 */
      int b = 13;    /* 13 = 0000 1101 */
      int c = 0;

      c = a & b;        /* 12 = 0000 1100 */
      System.out.println("a & b = " + c );

      c = a | b;        /* 61 = 0011 1101 */
      System.out.println("a | b = " + c );

      c = a ^ b;        /* 49 = 0011 0001 */
      System.out.println("a ^ b = " + c );

      c = ~a;           /*-61 = 1100 0011 */
      System.out.println("~a = " + c );

      c = a << 2;       /* 240 = 1111 0000 */
      System.out.println("a << 2 = " + c );

      c = a >> 2;       /* 15 = 1111 */
      System.out.println("a >> 2  = " + c );

      c = a >>> 2;      /* 15 = 0000 1111 */
      System.out.println("a >>> 2 = " + c );
   }
}

執行上面範例程式碼,得到以下結果:

a & b = 12
a | b = 61
a ^ b = 49
~a = -61
a << 2 = 240
a >> 2  = 15
a >>> 2 = 15