新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 單片機(jī)位操作的邏輯運(yùn)算詳解

單片機(jī)位操作的邏輯運(yùn)算詳解

作者: 時(shí)間:2016-11-30 來源:網(wǎng)絡(luò) 收藏
從51單片機(jī)轉(zhuǎn)到其他的芯片時(shí),總會(huì)遇到一個(gè)非常郁悶的問題,就是其他芯片有的也許沒有位操作。所以最大的問題就是通過邏輯操作來改變一個(gè)字節(jié)的某個(gè)位。于是在這里總結(jié)一下關(guān)于位操作的一些表達(dá)式。
首先,對(duì)一個(gè)字節(jié),8位也好,16位也好,32位也好,只有兩種操作,一種叫置位,一種叫清零。先從置位說起。
置位可以對(duì)全部位進(jìn)行操作,也可以對(duì)某個(gè)位進(jìn)行操作。
全部操作很簡單直接賦值就ok了。我們假設(shè)一個(gè)無符號(hào)字符型uchar為8位。且最低位為0,也就是說0-7位,而不是1-8位,那么改變值的狀態(tài)只需要直接等于就ok了
uchar a=0;
a=0xfe;
這樣的話,就讓a的低1-7位置1,a的0位不變
但這樣做有一個(gè)問題,我每次改變數(shù)值時(shí),還要先打開計(jì)算器,然后設(shè)置到2進(jìn)制功能,然后要把我要選擇的位輸入進(jìn)去,比如100,然后按16進(jìn)制功能。然后計(jì)算器顯示4。我覺得這樣很麻煩。咋辦呢,結(jié)果前輩們就想出了一個(gè)法子。通過位移的方法改變一個(gè)為,就變成了這樣
uchar a=0;
a = (1<<5);
這樣做的話,就把a(bǔ)的第6位(注意是第6為不是第5位,因?yàn)閿?shù)據(jù)最低位是0,而不是1,因?yàn)槲铱偸歉慊?,所以也告誡大家,小心著方面的錯(cuò)誤,如果搞混,你的數(shù)據(jù)有可能出錯(cuò))置1。那么a的值用2進(jìn)制表示的話那就是00100000b,那么可能又會(huì)有人問,如果我想把第2和第3位置1怎么辦呢?那么你可以這樣
uchar a=0;
a = (3<<1);
這樣做的意思是將二進(jìn)制(11)位移到第二位的地方。那么第二位,是第一個(gè)1,第三位是第二個(gè)1。同理假如讓第3位和低5位為1,第4位為0,怎么辦。
uchar a=0;
a = (5<<2);
這樣就可以實(shí)現(xiàn)101位移到第3位了,以上,基本是置位的大概操作了,當(dāng)然這只是一次性的。也就是說,如果我希望1次只操作一個(gè)位,比如當(dāng)a=00000001b時(shí),我希望a的第二位也置1,且第一位仍然保持1,怎么辦呢?那也有辦法,可以采用與操作。例如:a為1,我希望a的第2位置1,且第1位保持不變,那么
uchar a=1;
a |= (1<<1);
這樣就可以達(dá)到想要的結(jié)果了。然我們來看看,這是為什么?
首先,a=1,變成二進(jìn)制時(shí),a=00000001b
然后再看下面的那個(gè)表達(dá)式
a |= (1<<1);
分析一下,看過c語言相關(guān)書籍的人大概都知道這個(gè)一個(gè)含有復(fù)合的賦值運(yùn)算符的表達(dá)式。這個(gè)式子可以拆成:
a=a|(1<<1);
這樣就不難理解了,(1<<1)的意思是把1左移1位,那么結(jié)果就是10b,把這個(gè)結(jié)果在和a進(jìn)行或操作,我們知道或操作是同為0結(jié)果才是0。
a 00000001
或操作 00000010
結(jié)果 00000011
所以這個(gè)公式就可以使在不改變a=1的情況下,再使a的第2位變成1,這樣的結(jié)果就是a=3。這就是這個(gè)公式的大概原理。
上一頁 1 2 下一頁

評(píng)論


技術(shù)專區(qū)

關(guān)閉