位运算都是针对于二进制的计算方式,在计算时要转为二进制来处理。
一、基本定义
按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。
移动超出左边边界的位则直接抛弃。
x<带符号
右移
>>按二进制形式把所有的数字向右移动对应位移位数,低位移出(舍弃),高位的空位补符号位,即正数补零,负数补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< (2)清0 #define clrbit(x,y) x&=~(1< (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) (*pVal_16bit) = iAddr; //注意: //iAddr = ValH_8bit<<8+ValL_8bit;//这样的话,运行结果不对,所以需要临时变量把高位存起来比较安全。 欢迎分享,转载请注明来源:内存溢出
{
unsigned int iAddr;
unsigned int itemp;/
itemp = ValH_8bit;//
itemp = (itemp<<8);///
iAddr = (itemp + ValL_8bit);
}
评论列表(0条)