不帶進位位的單片機加法指令
ADD A,#DATA ;例:ADD A,#10H
ADD A,direct ;例:ADD A,10H
ADD A,Rn ;例:ADD A,R7
ADD A,@Ri ;例:ADD A,@R0
用途:將A中的值與(yu) 其後麵的值相加,最終結果否是回到A中。
例:MOV A,#30H
ADD A,#10H
則執行完本條指令後,A中的值為(wei) 40H。
下麵的題目自行練習(xi)
MOV 34H,#10H
MOV R0,#13H
MOV A,34H
ADD A,R0
MOV R1,#34H
ADD A,@R1
帶進位位的加法指令
ADDC A,Rn
ADDC A,direct
ADDC A,@Ri
ADDC A,#data
用途:將A中的值和其後麵的值相加,並且加上進位位C中的值。
說明:由於(yu) 51單片機是一種8位機,所以隻能做8位的數學運算,但8位運算的範圍隻有0-255,這在實際工作中是不夠的,因此就要進行擴展,一般是將2個(ge) 8位的數學運算合起來,成為(wei) 一個(ge) 16位的運算,這樣,能表達的數的範圍就能達到0-65535。如何合並呢?其實很簡單,讓我們(men) 看一個(ge) 10進製數的例程:
66+78。
這兩(liang) 個(ge) 數相加,我們(men) 根本不在意這的過程,但事實上我們(men) 是這樣做的:先做6+8(低位),然後再做6+7,這是高位。做了兩(liang) 次加法,隻是我們(men) 做的時候並沒有刻意分成兩(liang) 次加法來做罷了,或者說我們(men) 並沒有意識到我們(men) 做了兩(liang) 次加法。之所以要分成兩(liang) 次來做,是因為(wei) 這兩(liang) 個(ge) 數超過了一位數所能表達的範置(0-9)。
在做低位時產(chan) 生了進位,我們(men) 做的時候是在適當的位置點一下,然後在做高位加法是將這一點加進去。那麽(me) 計算機中做16位加法時同樣如此,先做低8位的,如果兩(liang) 數相加產(chan) 生了進位,也要“點一下”做個(ge) 標記,這個(ge) 標記就是進位位C,在PSW中。在進行高位加法是將這個(ge) C加進去。例:1067H+10A0H,先做67H+A0H=107H,而107H顯然超過了0FFH,因此最終保存在A中的是7,而1則到了PSW中的CY位了,換言之,CY就相當於(yu) 是100H。然後再做10H+10H+CY,結果是21H,所以最終的結果是2107H。
帶借位的單片機減法指令
SUBB A,Rn
SUBB A,direct
SUBB A,@Ri
SUBB A,#data
設(每個(ge) H,(R2)=55H,CY=1,執行指令SUBB A,R2之後,A中的值為(wei) 73H。
說明:沒有不帶借位的單片機減法指令,如果需要做不帶位的減法指令(在做第一次相減時),隻要將CY清零即可。
乘法指令
MUL AB
此單片機指令的功能是將A和B中的兩(liang) 個(ge) 8位無符號數相乘,兩(liang) 數相乘結果一般比較大,因此最終結果用1個(ge) 16位數來表達,其中高8位放在B中,低8位放在A中。在乘積大於(yu) FFFFFH(65535)時,0V置1(溢出),不然OV為(wei) 0,而CY總是0。
例:(A)=4EH,(B)=5DH,執行指令
MUL AB後,乘積是1C56H,所以在B中放的是1CH,而A中放的則是56H。
除法指令
DIV AB
此單片機指令的功能是將A中的8位無符號數除了B中的8位無符號數(A/B)。除法一般會(hui) 出現小數,但計算機中可沒法直接表達小數,它用的是我們(men) 小學生還沒接觸到小數時用的商和餘(yu) 數的概念,如13/5,其商是2,餘(yu) 數是3。除了以後,商放在A中,餘(yu) 數放在B中。CY和OV都是0。如果在做除法前B中的值是00H,也就是除數為(wei) 0,那麽(me) 0V=1。
加1指令
INC A
INC Rn
INC direct
INC @Ri
INC DPTR
用途很簡單,就是將後麵目標中的值加1。例:(A)=12H,(R0)=33H,(21H)=32H,(34H)=22H,DPTR=1234H。執行下麵的指令:
INC A (A)=13H
INC R2 (R0)=34H
INC 21H (21H)=33H
INC @R0 (34H)=23H
INC DPTR ( DPTR)=1235H
後結果如上所示。
說明:從(cong) 結果上看INC A和ADD A,#1差不多,但INC A是單字節,單周期指令,而ADD #1則是雙字節,雙周期指令,而且INC A不會(hui) 影響PSW位,如(A)=0FFH,INC A後(A)=00H,而CY依然保持不變。如果是ADD A ,#1,則(A)=00H,而CY一定是1。因此加1指令並不適合做加法,事實上它主要是用來做計數、地址增加等用途。另外,加法類指令都是以A為(wei) 核心的��其中一個(ge) 數必須放在A中,而運算結果也必須放在A中,而加1類指令的對象則廣泛得多,能是寄存器、內(nei) 存地址、間址尋址的地址等等。
減1指令
減1指令
DEC A
DEC RN
DEC direct
DEC @Ri
與(yu) 加1指令類似,就不多說了。
綜合練習(xi) :
MOV A,#12H
MOV R0,#24H
MOV 21H,#56H
ADD A,#12H
MOV DPTR,#4316H
ADD A,DPH
ADD A,R0
CLR C
SUBB A,DPL
SUBB A,#25H
INC A
SETB C
ADDC A,21H
INC R0
SUBB A,R0
MOV 24H,#16H
CLR C
ADD A,@R0
先寫(xie) 出每步運行結果,然後將以上題目建入,並在軟件仿真中運行,觀察寄存器及有關(guan) 單元的內(nei) 容的變化,是否與(yu) 自已的預想結果相同。