1> 功能
只有對(duì)應(yīng)的兩個(gè)二進(jìn)位均為1時(shí),結(jié)果位才為1,否則為0。
2> 舉例: 比如9&5,其實(shí)就是1001&101=1,因此9&5=1
3> 規(guī)律
二進(jìn)制中,與1相&就保持原位,與0相&就為0
1> 功能
只要對(duì)應(yīng)的二個(gè)二進(jìn)位有一個(gè)為1時(shí),結(jié)果位就為1,否則為0。
2> 舉例: 比如9|5,其實(shí)就是1001|101=1101,因此9|5=13
1> 功能
當(dāng)對(duì)應(yīng)的二進(jìn)位相異(不相同)時(shí),結(jié)果為1,否則為0。
2> 舉例: 比如9^5,其實(shí)就是1001^101=1100,因此9^5=12
3> 規(guī)律
相同整數(shù)相^的結(jié)果是0。比如5^5=0
多個(gè)整數(shù)相^的結(jié)果跟順序無關(guān)。比如5^6^7=5^7^6
因此得出結(jié)論:a^b^a = b
對(duì)整數(shù)a的各二進(jìn)位進(jìn)行取反,符號(hào)位也取反(0變1,1變0)
把整數(shù)a的各二進(jìn)位全部左移n位,高位丟棄,低位補(bǔ)0。左移n位其實(shí)就是乘以2的n次方
由于左移是丟棄最高位,0補(bǔ)最低位,所以符號(hào)位也會(huì)被丟棄,左移出來的結(jié)果值可能會(huì)改變正負(fù)性
把整數(shù)a的各二進(jìn)位全部右移n位,保持符號(hào)位不變。右移n位其實(shí)就是除以2的n次方
為正數(shù)時(shí), 符號(hào)位為0,最高位補(bǔ)0
為負(fù)數(shù)時(shí),符號(hào)位為1,最高位是補(bǔ)0或是補(bǔ)1 取決于編譯系統(tǒng)的規(guī)定
7.學(xué)習(xí)代碼
1 #include <stdio.h> 2 3 4 int main() 5 { 6 /* 按位與 & 7 8 10101010000 9 0000010000010 -------------11 0000000000012 13 1011101114 1010110115 ---------16 1010100117 18 100119 010120 -----21 000122 */23 24 /*25 按位或 |26 100127 010128 -----29 110130 */31 32 33 /*34 按位異或 ^ 35 1.相同數(shù)值進(jìn)行異或,結(jié)果肯定是0,比如9^936 2.交換 9^5^6 == 9^6^537 3.任何數(shù)值跟0進(jìn)行異或,結(jié)果還是原來的數(shù)值,9^0 == 938 4.a^b^a == a^a^b == 0^b == b39 40 100141 010142 -----43 110044 45 100146 100147 -----48 0000049 50 010151 000052 ----53 010154 55 9^5^9 == 9^9^5 = 0^5 = 556 57 a^b^a == b58 */59 //60 61 //printf("%d/n", 9 ^ 5);62 63 /*64 按位取反 ~65 ~0000 0000 0000 0000 0000 0000 0000 100166 1111 1111 1111 1111 1111 1111 1111 011067 */68 //printf("%d/n", ~9);69 70 /*71 左移 <<72 73 0000 0000 0000 0000 0000 0000 0000 000074 00 0000 0000 0000 0000 0000 0000 10010075 76 9<<1 -> 9 * 2的1次方 == 1877 9<<2 -> 9 * 2的2次方 ==3678 9<<n -> 9 * 2的n次方79 */80 81 //printf("%d/n", 9<<1);82 83 /*84 右移 >>85 0000 0000 0000 0000 0000 0000 0000 000086 000000 0000 0000 0000 0000 0000 0000 1087 111111 1111 1111 1111 1111 1111 1111 10 88 89 8>>1 -> 8/2 == 490 8>>2 -> 8/2的2次方 == 291 8>>n -> 8/2的n次方92 */93 94 printf("%d/n", 8>>3);95 96 return 0;97 }
1 #include <stdio.h> 2 3 /* 4 使用位異或運(yùn)算符交換兩個(gè)變量的值 5 */ 6 7 int main() 8 { 9 int a = 10;10 int b = 11;11 12 /* 借助第三方變量13 int temp = a;14 a = b;15 b = temp;16 */17 18 /*19 a = b - a;20 b = b - a;21 a = b + a;22 */23 24 // a^b^a == b25 26 // a --> 10^1127 // b --> 1028 a = a ^ b;29 b = a ^ b;30 a = a ^ b;31 32 printf("a=%d, b=%d/n", a, b);33 34 return 0;35 }
1 #include <stdio.h> 2 /* 3 用位與&運(yùn)算符判斷變量的奇偶性 4 */ 5 int main() 6 { 7 /* 8 15: 1111 9 9: 100110 11 14: 111012 10: 101013 */14 int a = 15;15 16 a&1 == 1 // 奇數(shù)17 a&1 == 0 // 偶數(shù)18 19 /*20 if (a%2) {21 printf("奇數(shù)/n");22 } else {23 printf("偶數(shù)/n");24 }*/25 26 //a%2==0?printf("偶數(shù)/n"):printf("奇數(shù)/n");27 28 //a%2?printf("奇數(shù)/n"):printf("偶數(shù)/n");29 30 31 32 return 0;33 }
1 /* 2 寫一個(gè)函數(shù),用來輸出整數(shù)在內(nèi)存中的二進(jìn)制形式 3 */ 4 5 #include <stdio.h> 6 void printBinary(int number); 7 8 int main() 9 {10 /*11 0000 0000 0000 0000 0000 0000 0000 000012 0000 0000 0000 0000 0000 0000 0000 111113 14 9 : 0000 0000 0000 0000 0000 0000 0000 100115 -10 : 1111 1111 1111 1111 1111 1111 1111 011016 */17 18 19 //printf("%d/n", ~9);20 21 22 printBinary(-10);23 return 0;24 }25 26 void printBinary(int number)27 {28 29 // 記錄現(xiàn)在挪到第幾位30 // (sizeof(number)*8) - 1 == 3131 int temp = ( sizeof(number)<<3 ) - 1;32 33 while ( temp >= 0 )34 {35 // 先挪位,再&1,取出對(duì)應(yīng)位的值36 int value = (number>>temp) & 1;37 printf("%d", value);38 39 // 40 temp--;41 42 // 每輸出4位,就輸出一個(gè)空格43 if ( (temp + 1) % 4 == 0 )44 {45 printf(" ");46 }47 }48 49 printf("/n");50 }
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注