Java定義了幾個按位元運算子,可以應用於整數型別, 如:long
,int
,short
,char
和byte
。按位元運算子處理位並執行逐位運算。 假設a = 60
且b = 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