按位元運算子對位執行,並執行逐位運算。&
,|
和^
的真值表如下 -
假設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
MATLAB提供了諸如「按位元與」和「按位元或」以及「按位元非」操作,移位元運算等位元運算的各種功能。
下表顯示了常用的按位元操作:
方法 | 目的 | ||
---|---|---|---|
bitand(a, b) | 整數a 和b 的位與AND 操作 |
||
bitcmp(a) | a 的位元二補數 |
||
bitget(a,pos) | 在整數陣列a 中,獲取指定的位置pos 位位元組 |
||
bitor(a, b) | 整數a 和b 的逐位OR 操作 |
||
bitset(a, pos) | 設定在指定pos 處的位位元組 |
||
bitshift(a, k) | 返回向左移位k 位元組,相當於乘以2^k 。 k 的負值對應於向右移位或除以`2^ |
k | ` 並捨入到最接近的整數到負無窮大。任何溢位位都被截斷。 |
bitxor(a, b) | 整數a 和b 的逐位元組位XOR 操作 |
||
swapbytes | 交換位元組排序 |
建立指令碼檔案並鍵入以下程式碼 -
a = 60; % 60 = 0011 1100
b = 13; % 13 = 0000 1101
c = bitand(a, b) % 12 = 0000 1100
c = bitor(a, b) % 61 = 0011 1101
c = bitxor(a, b) % 49 = 0011 0001
c = bitshift(a, 2) % 240 = 1111 0000 */
c = bitshift(a,-2) % 15 = 0000 1111 */
執行檔案時,會顯示以下結果 -
c = 12
c = 61
c = 49
c = 240
c = 15