不帶進位位的微控制器加法指令ADD A,#DATA ;例:ADD A,#10HADD A,direct ;例:ADD A,10HADD A,Rn ;例:ADD A,R7ADD A,@Ri ;例:ADD A,@R0用途:將A中的值與其後面的值相加,最終結果否是回到A中。例:MOV A,#30HADD A,#10H帶進位位的加法指令ADDC A,RnADDC A,directADDC A,@RiADDC A,#data用途:將A中的值和其後面的值相加,並且加上進位位C中的值。由於51微控制器是一種8位機,所以只能做8位的數學運算,但8位運算的範圍只有0-255,這在實際工作中是不夠的,因此就要進行擴充套件,一般是將2個8位的數學運算合起來,成為一個16位的運算,這樣,能表達的數的範圍就能達到0-65535如何合併呢?其實很簡單,讓我們看一個10進位制數的例程:66+78。這兩個數相加,我們根本不在意這的過程,但事實上我們是這樣做的:先做6+8(低位),然後再做6+7,這是高位。做了兩次加法,只是我們做的時候並沒有刻意分成兩次加法來做罷了,或者說我們並沒有意識到我們做了兩次加法。之所以要分成兩次來做,是因為這兩個數超過了一位數所能表達的範置(0-9)。在做低位時產生了進位,我們做的時候是在適當的位置點一下,然後在做高位加法是將這一點加進去。那麼計算機中做16位加法時同樣如此,先做低8位的,如果兩數相加產生了進位,也要“點一下”做個標記,這個標記就是進位位C,在PSW中。在進行高位加法是將這個C加進去。例:1067H+10A0H,先做67H+A0H=107H,而107H顯然超過了0FFH,因此最終儲存在A中的是7,而1則到了PSW中的CY位了,換言之,CY就相當於是100H。然後再做10H+10H+CY,結果是21H,所以最終的結果是2107H。至於資料如何定義到你要的位置,這個問題不用我教你了吧!!!
不帶進位位的微控制器加法指令ADD A,#DATA ;例:ADD A,#10HADD A,direct ;例:ADD A,10HADD A,Rn ;例:ADD A,R7ADD A,@Ri ;例:ADD A,@R0用途:將A中的值與其後面的值相加,最終結果否是回到A中。例:MOV A,#30HADD A,#10H帶進位位的加法指令ADDC A,RnADDC A,directADDC A,@RiADDC A,#data用途:將A中的值和其後面的值相加,並且加上進位位C中的值。由於51微控制器是一種8位機,所以只能做8位的數學運算,但8位運算的範圍只有0-255,這在實際工作中是不夠的,因此就要進行擴充套件,一般是將2個8位的數學運算合起來,成為一個16位的運算,這樣,能表達的數的範圍就能達到0-65535如何合併呢?其實很簡單,讓我們看一個10進位制數的例程:66+78。這兩個數相加,我們根本不在意這的過程,但事實上我們是這樣做的:先做6+8(低位),然後再做6+7,這是高位。做了兩次加法,只是我們做的時候並沒有刻意分成兩次加法來做罷了,或者說我們並沒有意識到我們做了兩次加法。之所以要分成兩次來做,是因為這兩個數超過了一位數所能表達的範置(0-9)。在做低位時產生了進位,我們做的時候是在適當的位置點一下,然後在做高位加法是將這一點加進去。那麼計算機中做16位加法時同樣如此,先做低8位的,如果兩數相加產生了進位,也要“點一下”做個標記,這個標記就是進位位C,在PSW中。在進行高位加法是將這個C加進去。例:1067H+10A0H,先做67H+A0H=107H,而107H顯然超過了0FFH,因此最終儲存在A中的是7,而1則到了PSW中的CY位了,換言之,CY就相當於是100H。然後再做10H+10H+CY,結果是21H,所以最終的結果是2107H。至於資料如何定義到你要的位置,這個問題不用我教你了吧!!!