你的位置:首页 > 软件开发 > 操作系统 > 【学习笔记】【C语言】位运算

【学习笔记】【C语言】位运算

发布时间:2015-06-20 00:00:12
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 (#换成@)。

可能感兴趣文章

我的浏览记录