單片機位操作的邏輯運算詳解
不僅這個,我還可以分別對兩個不同的位進行操作。所以我可以這樣:
uchar a=1;
a |= (1<<2)|(1<<3)|(1<<4)|(1<<5);
這樣的話,就可以把第3、4、5、6位全部置1,而且保持a的第1位不變,這個公式的最終結(jié)果是00111101b。 同樣,這招,在全部置位也有效。但是a原來的值就消失了
uchar a=1;
a = (1<<2)|(1<<3)|(1<<4)|(1<<5);
那么結(jié)果只有4個1,00111100b,第1位的一就沒有了
同樣比如(3<<1)也可以出現(xiàn)在單一置位當(dāng)中
uchar a=1
a |= (3<<1);
這個表達式結(jié)果為00000111b。到這,置位操作,基本上就都在這了,大多數(shù)程序,這幾個方法也夠了,這也是晚上普遍的方法,也許還有其他的方法,如果你知道,希望能夠通知我。下面說說清0,清0可以用(&=~),舉個例子:
uchar a=0xfe;
a &=~ (1<<4);
讓我們來分析一下這個式子,首先這和上面一樣,是一個含有復(fù)合的賦值運算符的表達式。拆開來以后
a=a&(~(1<<4))
這個式子比剛才要復(fù)雜一些,讓我們先來看看括號最里面的(1<<4)
結(jié)果為10000b,然后我們把這個式子取反,因為a是8位的,所以結(jié)果被轉(zhuǎn)換成11101111b,然后我們在把a和這個結(jié)果進行與運算。因為與運算的規(guī)律是全1為1。
a 11111110b
與操作 11101111b
結(jié)果 11101110b
現(xiàn)在,我們清楚了這個結(jié)果時怎么來的了。
同樣同時使兩位變?yōu)?也可以通過(3<<5)來實現(xiàn),比如
uchar a=0xfe;
a &=~ (3<<4);
這樣也是可以得到希望的結(jié)果的,但是需要注意一下,(1<<2)|(1<<3)|(1<<4)|(1<<5),像這種一位一位的變則需要注意一下了。因為清零中先需要取反,所以如果希望一位一位的變,則需要用括號,把結(jié)果擴起來,形成一個值,然后再取反,才能得到想要的結(jié)果了。比如
uchar a=0xfe;
/*
注意,這樣做是不對的,結(jié)果只會把第二位清0,
a &=~ (1<<2)|(1<<3)|(1<<4)|(1<<5);
*/
a &=~ ((1<<2)|(1<<3)|(1<<4)|(1<<5));
這樣做才能達到希望的效果。
可能大家會想,用(&=)會得到啥樣的結(jié)果呢?這我試了一下
uchar a=0xfe
a &= (1<<4);
首先(1<<4),結(jié)果是10000,然后再進行與操作
a 11111110b
與操作 00010000b
結(jié)果 00010000b
這個結(jié)果不是我們想要的,不過這個結(jié)果可以達到屏蔽我們不要的位,比如在判斷中,判斷最高位是否為1,可以采用這樣的語句
if(a&0x80)
這句話,如果a的最高位為1,則為真,如果最高位不為1,則為假,如果位最高位為1的話,結(jié)果為10000000,在c語言中不為0,則為真,所以判定某位是否為1時,可以采用&操作。
關(guān)鍵詞:
單片機位操作邏輯運
評論