51單片機(jī)匯編語(yǔ)言帶進(jìn)位加法指令
這4條指令除與[1]功能相同外,在進(jìn)行加法運(yùn)算時(shí)還需考慮進(jìn)位問(wèn)題。
ADDC A,data ;(A)+(data)+(C)→(A) 累加器A中的內(nèi)容與直接地址單元的內(nèi)容連同進(jìn)位位相加,結(jié)果存在A中
ADDC A,#data ;(A)+#data +(C)→(A) 累加器A中的內(nèi)容與立即數(shù)連同進(jìn)位位相加,結(jié)果存在A中
ADDC A,Rn ;(A)+Rn+(C)→(A) 累加器A中的內(nèi)容與工作寄存器Rn中的內(nèi)容、連同進(jìn)位位相加,結(jié)果存在A中
ADDC A,@Ri ;(A)+((Ri))+(C)→(A) 累加器A中的內(nèi)容與工作寄存器Ri指向地址單元中的內(nèi)容、連同進(jìn)位位相加,結(jié)果存在A中用途:將A中的值和其后面的值相加,并且加上進(jìn)位位C中的值。
說(shuō)明:由于51單片機(jī)是一種8位機(jī),所以只能做8位的數(shù)學(xué)運(yùn)算,但8位的運(yùn)算范圍只有0-255,這在實(shí)際工作中是不夠的,因此就要進(jìn)行擴(kuò)展,一般是將2個(gè)8位的數(shù)學(xué)運(yùn)算合起來(lái),成為一個(gè)16位的運(yùn)算,這樣,可以表達(dá)的數(shù)的范圍就可以到達(dá)0-65535。如何合并呢?其實(shí)很簡(jiǎn)單,讓我們看一個(gè)十進(jìn)制數(shù)的例子吧:
66+78
這兩個(gè)數(shù)相加,我們根本不在意這個(gè)過(guò)程,但事實(shí)上我們是這樣做的:先做6+8(低位),然后再做6+7,這是高位。做了兩次加法,只是我們做的時(shí)候并沒(méi)有刻意分成兩次加法來(lái)做罷了,或者說(shuō)我們并沒(méi)有意識(shí)到我們做了兩次加法。之所以要分成兩次來(lái)做,是因?yàn)檫@兩個(gè)數(shù)超過(guò)了一位數(shù)所能表達(dá)的范圍(0-9)。
在做低位時(shí)產(chǎn)生了進(jìn)位,我們做的時(shí)候是在適當(dāng)?shù)奈恢命c(diǎn)一下,然后在做高位加法時(shí)將這一點(diǎn)加進(jìn)去。那么計(jì)算機(jī)中做16位加法時(shí)同樣如此,先做低8位的,如果兩數(shù)相加后產(chǎn)生了進(jìn)位,也要“點(diǎn)一下”做個(gè)標(biāo)記,這個(gè)標(biāo)記就職進(jìn)位位C,在程序狀態(tài)字PSW中。在進(jìn)行高位加法是將這個(gè)C加進(jìn)去。
例如:1067H+10A0H,先做67H+A0H=107H,而107H顯然超過(guò)了0FFH,因此,最終保存在A中的數(shù)是7,而1則到了PSW中的CY位了,換言之,CY就相當(dāng)于100H。然后再做10H+10H+CY,結(jié)果是21H,所以最終的結(jié)果是2107H。
評(píng)論