按位與、或、非、異或總結(jié)

位運(yùn)算符有:&(按位與)、|(按位或)、^(按位異或)、~ (按位取反)。

優(yōu)先級(jí)從高到低,依次為~、&、^、|
1. 按位與操作 0&0=0; 0&1=0; 1&0=0; 1&1=1
  • 例子:10&9: 0000 1010 & 0000 1001 = 0000 1000 = 8

負(fù)數(shù)按補(bǔ)碼形式參加按位與運(yùn)算

  • “與運(yùn)算”的特殊用途:
    (1)清零。如果想將一個(gè)單元清零,即使其全部二進(jìn)制位為0,只要與一個(gè)各位都為零的數(shù)值相與,結(jié)果為零。
    (2)取一個(gè)數(shù)中指定位
    方法:找一個(gè)數(shù),對(duì)應(yīng)X要取的位,該數(shù)的對(duì)應(yīng)位為1,其余位為零,此數(shù)與X進(jìn)行“與運(yùn)算”可以得到X中的指定位。
    例:設(shè)X=10101110,
    取X的低4位,用 X & 0000 1111 = 0000 1110 即可得到;
    還可用來(lái)取X的2、4、6位。

2. 按位或運(yùn)算符(|)
  • 參加運(yùn)算的兩個(gè)對(duì)象,按二進(jìn)制位進(jìn)行“或”運(yùn)算。

  • 運(yùn)算規(guī)則:0|0=0; 0|1=1; 1|0=1; 1|1=1;

    • 即 :參加運(yùn)算的兩個(gè)對(duì)象只要有一個(gè)為1,其值為1。
  • 例如:3|5 即 0000 0011 | 0000 0101 = 0000 0111 因此,3|5的值得7。

另,負(fù)數(shù)按補(bǔ)碼形式參加按位或運(yùn)算。

  • “或運(yùn)算”特殊作用:

    • 常用來(lái)對(duì)一個(gè)數(shù)據(jù)的某些位置1。

      • 方法:找到一個(gè)數(shù),對(duì)應(yīng)X要置1的位,該數(shù)的對(duì)應(yīng)位為1,其余位為零。此數(shù)與X相或可使X中的某些位置1。

      • 例:將X=10100000的低4位置1 ,用 X | 0000 1111 = 1010 1111即可得到。


3. 異或運(yùn)算符(^)
  • 參加運(yùn)算的兩個(gè)數(shù)據(jù),按二進(jìn)制位進(jìn)行“異或”運(yùn)算。

  • 運(yùn)算規(guī)則:0^0=0; 0^1=1; 1^0=1; 1^1=0;

    • 即:參加運(yùn)算的兩個(gè)對(duì)象,如果兩個(gè)相應(yīng)位為“異”(值不同),則該位結(jié)果為1,否則為0。
  • 例如:10^-9 即 0000 1010 ^ 1111 0111 = 1111 1101(補(bǔ)碼) 原碼即為1000 0011 即10^-9 = -3


  • “異或運(yùn)算”的特殊作用:

    (1)使特定位翻轉(zhuǎn) 找一個(gè)數(shù),對(duì)應(yīng)X要翻轉(zhuǎn)的各位,該數(shù)的對(duì)應(yīng)位為1,其余位為零,此數(shù)與X對(duì)應(yīng)位異或即可。

    • 例:X=10101110,使X低4位翻轉(zhuǎn),用X ^ 0000 1111 = 1010 0001即可得到。

    (2)與0相異或,保留原值 ,X ^ 0000 0000 = 1010 1110。

    (3)交換a和b

    方法一 方法二
    1.a=a^b 1.a= a-b
    2.b=b^a 2.b= a+b
    3.a=a^b 3.a= b-a
4. 取反運(yùn)算符(~)
  • 參加運(yùn)算的一個(gè)數(shù)據(jù),按二進(jìn)制位進(jìn)行“取反”運(yùn)算。

  • 運(yùn)算規(guī)則:~1=0; ~0=1;

    • 即:對(duì)一個(gè)二進(jìn)制數(shù)按位取反,即將0變1,1變0。
  • 使一個(gè)數(shù)的最低位為零,可以表示為:a&~1。

  • ~1的值為1111111111111110,再按“與”運(yùn)算,最低位一定為0。因?yàn)椤皛”運(yùn)算符的優(yōu)先級(jí)比算術(shù)運(yùn)算符、關(guān)系運(yùn)算符、邏輯運(yùn)算符和其他運(yùn)算符都高。

5. 左移運(yùn)算符(<<)
  • 將一個(gè)運(yùn)算對(duì)象的各二進(jìn)制位全部左移若干位(左邊的二進(jìn)制位丟棄,右邊補(bǔ)0)。

  • 例:a = a << 2 將a的二進(jìn)制位左移2位,右補(bǔ)0,

  • 左移1位后a = a * 2;

  • 若左移時(shí)舍棄的高位不包含1,則每左移一位,相當(dāng)于該數(shù)乘以2。

6. 右移運(yùn)算符(>>)
  • 將一個(gè)數(shù)的各二進(jìn)制位全部右移若干位,正數(shù)左補(bǔ)0,負(fù)數(shù)左補(bǔ)1,右邊丟棄。

  • 操作數(shù)每右移一位,相當(dāng)于該數(shù)除以2。

    • 例如:a = a >> 2 將a的二進(jìn)制位右移2位,
      左補(bǔ)0 or 補(bǔ)1 得看被移數(shù)是正還是負(fù)。
  • >> 運(yùn)算符把 expression1 的所有位向右移 expression2 指定的位數(shù)。expression1 的符號(hào)位被用來(lái)填充右移后左邊空出來(lái)的位。向右移出的位被丟棄。

    • 例如,下面的代碼被求值后,temp 的值是 -4:
      var temp = -14 >> 2
      -14 (即二進(jìn)制的 11110010)右移兩位等于 -4 (即二進(jìn)制的 11111100)。
  • 無(wú)符號(hào)右移運(yùn)算符(>>>)

  • >>> 運(yùn)算符把 expression1 的各個(gè)位向右移 expression2 指定的位數(shù)。右移后左邊空出的位用零來(lái)填充。移出右邊的位被丟棄。

7. 復(fù)合賦值運(yùn)算符
  • 位運(yùn)算符與賦值運(yùn)算符結(jié)合,組成新的復(fù)合賦值運(yùn)算符,它們是:
位運(yùn)算符 例子 相當(dāng)于
&= 例:a &= b 相當(dāng)于a=a & b
|= 例:a |= b 相當(dāng)于a=a | b
>>= 例:a >>= b 相當(dāng)于a=a >> b
<<= 例:a <<= b 相當(dāng)于a=a << b
^= 例:a ^= b 相當(dāng)于a=a ^ b
  • 運(yùn)算規(guī)則:和前面講的復(fù)合賦值運(yùn)算符的運(yùn)算規(guī)則相似。

不同長(zhǎng)度的數(shù)據(jù)進(jìn)行位運(yùn)算

如果兩個(gè)不同長(zhǎng)度的數(shù)據(jù)進(jìn)行位運(yùn)算時(shí),系統(tǒng)會(huì)將二者按右端對(duì)齊,然后進(jìn)行位運(yùn)算。

以“與”運(yùn)算為例說(shuō)明如下:我們知道在C語(yǔ)言中l(wèi)ong型占4個(gè)字節(jié),int型占2個(gè)字節(jié),如果一個(gè)long型數(shù)據(jù)與一個(gè)int型數(shù)據(jù)進(jìn)行“與”運(yùn)算,右端對(duì)齊后,左邊不足的位依下面三種情況補(bǔ)足,

(1)如果整型數(shù)據(jù)為正數(shù),左邊補(bǔ)16個(gè)0。
(2)如果整型數(shù)據(jù)為負(fù)數(shù),左邊補(bǔ)16個(gè)1。

(3)如果整形數(shù)據(jù)為無(wú)符號(hào)數(shù),左邊也補(bǔ)16個(gè)0。

如:long a=123;int b=1;計(jì)算a & b。

a&b
a 0000 0000 0111 1011
b 0000 0000 0000 0001
= 0000 0000 0000 0001

如:long a=123;int b=-1;計(jì)算a & b。

a&b
a 0000 0000 0111 1011
b 1111 1111 1111 1111
= 0000 0000 0111 1011

如:long a=123;unsigned int b=1;計(jì)算a & b。

a&b
a 0000 0000 0111 1011
b 0000 0000 0000 0001
= 0000 0000 0000 0001
8. 原碼、反碼、補(bǔ)碼,負(fù)數(shù)表示法
  • 原碼:5 => 0b101,1 => 0b1 ,-1 => -0b1, bin(-1)
  • 反碼:
    • 正數(shù)的反碼與原碼相同;負(fù)數(shù)的反碼符號(hào)位不變其余按位取反
  • 補(bǔ)碼:
    • 正數(shù)的補(bǔ)碼與原碼相同;負(fù)數(shù)的補(bǔ)碼符號(hào)位不變其余按位取反后+1
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容