stm32库函数编程位操作总结

所谓位运算,就是对一个比特(Bit)位进行操作。在《数据在内存中的存储》一节中讲到,比特(Bit)是一个电子元器件,8个比特构成一个字节(Byte),它已经是粒度最小的可操作单元了。
C语言提供了六种运算符

运算符 & | ^ ~ << >>
说明 按位与 按位或 按位异或 取反 左移 右移

左移运算(<<)

左移运算符<<用来把操作数的各个二进制位全部左移若干位,高位丢弃,低位补0。

右移运算(>>)

右移运算符>>用来把操作数的各个二进制位全部右移若干位,低位丢弃,高位补 0 或 1。如果数据的最高位是 0,那么就补 0; 如果最高位是 1,那么就补 1。

stm32库函数编程常用的位操作

1)把变量的某位清零。

```c
1 //定义一个变量 a = 1001 1111 b (二进制数)
2 unsigned char a = 0x9f;
3 
4 //对 bit2 清零
5 
6 a &= ~(1<<2);
7 
8 //括号中的 1 左移两位,(1<<2)得二进制数:0000 0100 b
9 //按位取反,~(1<<2)得 1111 1011 b
10 //假如 a 中原来的值为二进制数: a = 1001 1111 b
11 //所得的数与 a 作”位与&”运算,a = (1001 1111 b)&(1111 1011 b),
12 //经过运算后,a 的值 a=1001 1011 b
13 // a 的 bit2 位被被零,而其它位不变

2) 把变量的某几个连续位清零

1 
2 //若把 a 中的二进制位分成 2 个一组
3 //即 bit0、bit1 为第 0 组,bit2、bit3 为第 1 组,
4 // bit4、bit5 为第 2 组,bit6、bit7 为第 3 组
5 //要对第 1 组的 bit2、bit3 清零
6 
7 a &= ~(3<<2*1);
8 
9 //括号中的 3 左移两位,(3<<2*1)得二进制数:0000 1100 b
10 //按位取反,~(3<<2*1)得 1111 0011 b
11 //假如 a 中原来的值为二进制数: a = 1001 1111 b
12 //所得的数与 a 作”位与&”运算,a = (1001 1111 b)&(1111 0011 b),
13 //经过运算后,a 的值 a=1001 0011 b
14 // a 的第 1 组的 bit2、bit3 被清零,而其它位不变。
15 
16 //上述(~(3<<2*1))中的(1)即为组编号;如清零第 3 组 bit6、bit7 此处应为 3
17 //括号中的(2)为每组的位数,每组有 2 个二进制位;若分成 4 个一组,此处即为 4
18 //括号中的(3)是组内所有位都为 1 时的值;若分成 4 个一组,此处即为二进制数“1111 b”
19 
20 //例如对第 2 组 bit4、bit5 清零
21 a &= ~(3<<2*2);

3)对变量的某几位进行赋值。

1 //a = 1000 0011 b
2 //此时对清零后的第 2 组 bit4、bit5 设置成二进制数“01 b ”
3 
4 a |= (1<<2*2);
5 //a = 1001 0011 b,成功设置了第 2 组的值,其它组不变
  

4)对变量的某位取反

1 //a = 1001 0011 b
2 //把 bit6 取反,其它位不变
3 
4 a ^=(1<<6);
5 //a = 1101 0011 b

与0异或不变,与1异或取反。

你可能感兴趣的:(C语言学习笔记)