1. & 按位与1> 功能只有对应的两个二进位均为1时,结果位才为1,否则为0。2> 举例: 比如9&5,其实就是1001&101=1,因此9&5=13> 规律二进制中,与1相&就保持原位,与0相&就为02. | ...
1. & 按位与
1> 功能
只有对应的两个二进位均为1时,结果位才为1,否则为0。
2> 举例: 比如9&5,其实就是1001&101=1,因此9&5=1
3> 规律
二进制中,与1相&就保持原位,与0相&就为0
2. | 按位或
1> 功能
只要对应的二个二进位有一个为1时,结果位就为1,否则为0。
2> 举例: 比如9|5,其实就是1001|101=1101,因此9|5=13
3. ^ 按位异或
1> 功能
当对应的二进位相异(不相同)时,结果为1,否则为0。
2> 举例: 比如9^5,其实就是1001^101=1100,因此9^5=12
3> 规律
相同整数相^的结果是0。比如5^5=0
多个整数相^的结果跟顺序无关。比如5^6^7=5^7^6
因此得出结论:a^b^a = b
4. ~ 取反
对整数a的各二进位进行取反,符号位也取反(0变1,1变0)
5. << 左移
把整数a的各二进位全部左移n位,高位丢弃,低位补0。左移n位其实就是乘以2的n次方
由于左移是丢弃最高位,0补最低位,所以符号位也会被丢弃,左移出来的结果值可能会改变正负性
6. >> 右移
把整数a的各二进位全部右移n位,保持符号位不变。右移n位其实就是除以2的n次方
为正数时, 符号位为0,最高位补0
为负数时,符号位为1,最高位是补0或是补1 取决于编译系统的规定
7.学习代码
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.相同数值进行异或,结果肯定是0,比如9^936 2.交换 9^5^6 == 9^6^537 3.任何数值跟0进行异或,结果还是原来的数值,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 //printf("%d\n", 9^9);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 }
海外公司注册、海外银行开户、跨境平台代入驻、VAT、EPR等知识和在线办理:https://www.xlkjsw.com
原标题:【学习笔记】【C语言】位运算
关键词:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。