<strong><font color="#004a85">一、把变量的某位清零</font> </strong>
<pre style="overflow-x:auto; background-color:#e9e9e9;">//定义一个变量 a = 1001 1111 b (二进制数)
unsigned char a = 0x9f;
//对 bit2 清零
a &= ~(1<<2);
//括号中的 1 左移两位,(1<<2)得二进制数:0000 0100 b
//按位取反,~(1<<2)得 1111 1011 b
//假如 a 中原来的值为二进制数: a = 1001 1111 b
//所得的数与 a 作”位与&”运算,a = (1001 1111 b)&(1111 1011 b),
//经过运算后,a 的值 a=1001 1011 b 13 // a 的 bit2 位被被零,而其它位不变</pre>
使用 a&=~(1<<x);可以将第x位清零;
<strong><font color="#004a85">二、把变量的某几个连续位清零</font> </strong>
<pre style="overflow-x:auto; background-color:#e9e9e9;">//若把 a 中的二进制位分成 2 个一组
//即 bit0、bit1 为第 0 组,bit2、bit3 为第 1 组,
// bit4、bit5 为第 2 组,bit6、bit7 为第 3 组
//要对第 1 组的 bit2、bit3 清零
a &= ~(3<<2*1);
//括号中的 3 左移两位,(3<<2*1)得二进制数:0000 1100 b
//按位取反,~(3<<2*1)得 1111 0011 b
//假如 a 中原来的值为二进制数: a = 1001 1111 b
//所得的数与 a 作”位与&”运算,a = (1001 1111 b)&(1111 0011 b),
//经过运算后,a 的值 a=1001 0011 b 14 // a 的第 1 组的 bit2、bit3 被清零,而其它位不变。
//上述(~(3<<2*1))中的(1)即为组编号;如清零第 3 组 bit6、bit7 此处应为 3
//括号中的(2)为每组的位数,每组有 2 个二进制位;若分成 4 个一组,此处即为 4
//括号中的(3)是组内所有位都为 1 时的值;若分成 4 个一组,此处即为二进制数“1111 b”
//例如对第 2 组 bit4、bit5 清零
a &= ~(3<<2*2);</pre>
使用a&=~((2^m-1)<<m*n) m个为一组 第n组清零
<strong><font color="#004a85">三、对变量的某几位进行赋值</font> </strong>
<pre style="overflow-x:auto; background-color:#e9e9e9;">//a = 1000 0011 b
//此时对清零后的第 2 组 bit4、bit5 设置成二进制数“01 b ”
a |= (1<<2*2);
//a = 1001 0011 b,成功设置了第 2 组的值,其它组不变 </pre>
使用a|=(Q<<m*n) m个为一组,设置第n组的值为Q
<strong><font color="#004a85">四、对变量的某位取反</font> </strong>
<pre style="overflow-x:auto; background-color:#e9e9e9;">//a = 1001 0011 b
//把 bit6 取反,其它位不变
a ^=(1<<6);
//a = 1101 0011 b </pre>
使用a^=(1<<m) 使第m位取反
小结:赋值使用或|,清零使用与&,取反使用异或^。
版权声明:本文为CSDN博主「嵌入式小白woods」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_35358125/article/details/101157270