C语言(嵌入式)位操作个人总结

位运算都是针对于二进制的计算方式,在计算时要转为二进制来处理。

一、基本定义

位操作符号含义规则
&两个数都为1结果才为1,否则为00&0=0,0&1=0,1&0=0,1&1=1
|只要有一个数为1,结果就为1,两个都是0时结果才是00|0=0,0|1=1,1|0=1,1|1=1
异或^如果两个数相同,则返回0,如果不相同则返回10^0=0,0^1=1,1^0=1,1^1=0
取反~将1变为0,0变为1~1=0,~0=1
左移<<

按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零

移动超出左边边界的位则直接抛弃。

x<<y,
x 的每个位向左移动 y 个位

带符号

右移

>>

按二进制形式把所有的数字向右移动对应位移位数,低位移出(舍弃),高位的空位补符号位,即正数补零,负数补1。

如果左操作数是无符号类型,或者左操作数是带符号类型但为非负值,则左边多出来的位用 0 来填充;

如果左操作数是负值,那么由编译器决定用于填充至左边多出来的位的内容,可能是 0,也可能是符号位。

x>>y,
x 的每个位向右移动 y 个位
 

无符号

右移

>>>二进制形式把所有的数字向右移动对应位数,低位移出(舍弃),高位的空位补零对于正数来说和带符号右移相同,对于负数来说不同。

二、操作方式总结

1.设置特定的位用|;
2.清除特定的位用&;
3.取反特定的位用^;
4.取反所有的位用~;

位运算符也可以用来生成位掩码,以供以后的位运算使用。

例如:位掩码 ~0x20 比 0xFFFFFFDF 更受欢迎,因为它的可移植性更好:结果不会受到机器字大小的影响(同时也更方便人阅读)。


5.移位运算符的操作数必须是整数。在实际移位操作之前,两个操作数都要进行整数提升。右边操作数不可以为负值,并且必须少于左边操作数在整数提升之后的位长。如果不符合这些条件,程序运行结果将无法确定。

三、常用方法

嵌入式中经常要对指定bit进行操作,置1,清0,读取等操作;

(1)置1

        #define setbit(x,y)  x|=(1<<y)

(2)清0

        #define clrbit(x,y)  x&=~(1<<y)

(3)判断

        #define getbit(x,y)   ((x) >> (y)&1)

三、踩过的坑

例:把2个地址合并成一个地址 

void Merge_2x8bit_To_16bit(unsigned char ValH_8bit,unsigned char ValL_8bit,unsigned int * pVal_16bit)
{
    unsigned int iAddr;
    unsigned int itemp;/
    itemp = ValH_8bit;//
    itemp = (itemp<<8);///
    
    iAddr = (itemp + ValL_8bit);

       (*pVal_16bit) = iAddr;  

//注意:

//iAddr = ValH_8bit<<8+ValL_8bit;//这样的话,运行结果不对,所以需要临时变量把高位存起来比较安全。
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值