新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 单片机位操作的逻辑运算详解

单片机位操作的逻辑运算详解

作者: 时间:2016-11-30 来源:网络 收藏
不仅这个,我还可以分别对两个不同的位进行操作。所以我可以这样:
uchar a=1;
a |= (1<<2)|(1<<3)|(1<<4)|(1<<5);
这样的话,就可以把第3、4、5、6位全部置1,而且保持a的第1位不变,这个公式的最终结果是00111101b。 同样,这招,在全部置位也有效。但是a原来的值就消失了
uchar a=1;
a = (1<<2)|(1<<3)|(1<<4)|(1<<5);
那么结果只有4个1,00111100b,第1位的一就没有了
同样比如(3<<1)也可以出现在单一置位当中
uchar a=1
a |= (3<<1);
这个表达式结果为00000111b。到这,置位操作,基本上就都在这了,大多数程序,这几个方法也够了,这也是晚上普遍的方法,也许还有其他的方法,如果你知道,希望能够通知我。下面说说清0,清0可以用(&=~),举个例子:
uchar a=0xfe;
a &=~ (1<<4);
让我们来分析一下这个式子,首先这和上面一样,是一个含有复合的赋值运算符的表达式。拆开来以后
a=a&(~(1<<4))
这个式子比刚才要复杂一些,让我们先来看看括号最里面的(1<<4)
结果为10000b,然后我们把这个式子取反,因为a是8位的,所以结果被转换成11101111b,然后我们在把a和这个结果进行与运算。因为与运算的规律是全1为1。
a 11111110b
与操作 11101111b
结果 11101110b
现在,我们清楚了这个结果时怎么来的了。
同样同时使两位变为0也可以通过(3<<5)来实现,比如
uchar a=0xfe;
a &=~ (3<<4);
这样也是可以得到希望的结果的,但是需要注意一下,(1<<2)|(1<<3)|(1<<4)|(1<<5),像这种一位一位的变则需要注意一下了。因为清零中先需要取反,所以如果希望一位一位的变,则需要用括号,把结果扩起来,形成一个值,然后再取反,才能得到想要的结果了。比如
uchar a=0xfe;
/*
注意,这样做是不对的,结果只会把第二位清0,
a &=~ (1<<2)|(1<<3)|(1<<4)|(1<<5);
*/
a &=~ ((1<<2)|(1<<3)|(1<<4)|(1<<5));
这样做才能达到希望的效果。
可能大家会想,用(&=)会得到啥样的结果呢?这我试了一下
uchar a=0xfe
a &= (1<<4);
首先(1<<4),结果是10000,然后再进行与操作
a 11111110b
与操作 00010000b
结果 00010000b
这个结果不是我们想要的,不过这个结果可以达到屏蔽我们不要的位,比如在判断中,判断最高位是否为1,可以采用这样的语句
if(a&0x80)
这句话,如果a的最高位为1,则为真,如果最高位不为1,则为假,如果位最高位为1的话,结果为10000000,在c语言中不为0,则为真,所以判定某位是否为1时,可以采用&操作。
以上就是简单的总结了一下置位,清零的逻辑操作的方法。
上一页 1 2 下一页

评论


技术专区

关闭