C语言位操作

1.清零

//定义一个变量 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
// a 的 bit2 位被被零,而其它位不变。

2. 连续多位清零

 //若把 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
 // 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);

3. 置位

 //a = 1000 0011 b
 //此时对清零后的第 2 组 bit4、 bit5 设置成二进制数“01 b ”

 a |= (1<<2*2);
 //a = 1001 0011 b,成功设置了第 2 组的值,其它组不变

4.取反

 //a = 1001 0011 b
 //把 bit6 取反,其它位不变

 a ^=(1<<6);
 //a = 1101 0011 b

5.亦或交换两个变量

int a=5,b=10;
a=a^b;
b=b^a;
a=a^b;

6.求余数

int a=175;//求被4整除的余数,不用除法和模运算
int b=a-(a&~3);//(a&~3)抹掉余数
不能被4整除的部分说明,最后2位为011011

7.取出高8位和低8位

//IP数据报总长度高字节

IpHeadUint8[10]=(IpHead.e_ip.Crc&0xff00)>>8;

//IP数据报总长度低字节

IpHeadUint8[11]=IpHead.e_ip.Crc&0x00ff;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值