算術(shù)運(yùn)算指令知識(shí)匯總
算術(shù)運(yùn)算指令包括加、減、乘和除法指令,其語(yǔ)法格式見表3-7。由表3-7可知,算術(shù)運(yùn)算指令會(huì)對(duì)PSW中的某些位產(chǎn)生影響。
1.加法指令A(yù)DD和ADDC
ADD指令將源操作數(shù)和累加器A中的數(shù)相加,加法的結(jié)果存入累加器A,并且運(yùn)算結(jié)果會(huì)影響PSW中的CY、OV、AC和P標(biāo)志位。ADD指令對(duì)標(biāo)志位的影響如下:當(dāng)加法結(jié)果的第7位有進(jìn)位時(shí),則進(jìn)位標(biāo)志位CY被置1,否則被清0;如果加法結(jié)果的第3位有進(jìn)位,則輔助進(jìn)位標(biāo)志位AC被置1,否則被清0;如果加法結(jié)果的第6位和第7位的進(jìn)位情況不一致,則溢出標(biāo)志位OV被置1,否則被清0;運(yùn)算結(jié)束時(shí),奇偶標(biāo)志位P的值由累加器A中的數(shù)決定,若累加器A中的值以二進(jìn)制表示后,其中“1”的個(gè)數(shù)為奇數(shù)個(gè),則P為1,否則P為0。
ADDC指令與ADD指令的唯一區(qū)別是,前者在源操作數(shù)和累加器A的加法基礎(chǔ)上再加上CY中的值。
2.十進(jìn)制調(diào)整指令DA
指令A(yù)DD和ADDC將其源操作數(shù)和目的操作數(shù)作為二進(jìn)制數(shù)(或十六進(jìn)制數(shù))進(jìn)行加法計(jì)算,遵循“逢2進(jìn)1”(或“逢16進(jìn)1”)的二進(jìn)制(或十六進(jìn)制)計(jì)算規(guī)則,得到的運(yùn)算結(jié)果為二進(jìn)制數(shù)(或十六進(jìn)制數(shù))。如果用ADD和ADDC指令進(jìn)行壓縮BCD碼(十進(jìn)制數(shù))的加法計(jì)算,則得不到正確的十進(jìn)制計(jì)算結(jié)果,而使用DA指令可以將ADD和ADDC指令的運(yùn)算結(jié)果調(diào)整為十進(jìn)制的運(yùn)算結(jié)果。
使用“DA A”指令進(jìn)行十進(jìn)制調(diào)整時(shí),必須滿足以下要求:在DA指令之前必須進(jìn)行ADD或ADDC加法運(yùn)算,并且參與加法運(yùn)算的操作數(shù)必須是壓縮BCD碼數(shù)。
“DA A”指令調(diào)整時(shí),先處理“個(gè)位”,再處理“十位”,“個(gè)位”的處理結(jié)果將影響“十位”的調(diào)整,具體步驟如下:
(1)調(diào)整BCD碼運(yùn)算結(jié)果的“個(gè)位”
1)若累加器A中運(yùn)算結(jié)果的“個(gè)位”(即低4位)數(shù)大于9(非BCD碼),則在累加器A的“個(gè)位”上加“6”。這樣做是因?yàn)椋涸贐CD碼計(jì)算時(shí),結(jié)果大于9則應(yīng)產(chǎn)生進(jìn)位,但是ADD和ADDC按照十六進(jìn)制進(jìn)行計(jì)算,只有結(jié)果大于15時(shí)才進(jìn)位,從而導(dǎo)致“晚”進(jìn)位,所以此時(shí)加“6”相當(dāng)于將“逢16進(jìn)1”的十六進(jìn)制運(yùn)算強(qiáng)制調(diào)整為“逢10進(jìn)1”十進(jìn)制運(yùn)算。
2)若累加器A中運(yùn)算結(jié)果的“個(gè)位”(即低4位)產(chǎn)生進(jìn)位(輔助進(jìn)位標(biāo)志位(AC)=1),則在累加器A的“個(gè)位”上加“6”。這樣處理的理由是:“個(gè)位”產(chǎn)生進(jìn)位,意味著BCD碼加法結(jié)果的個(gè)位大于15而產(chǎn)生了進(jìn)位,但是該進(jìn)位將使BCD碼加法結(jié)果的個(gè)位數(shù)被減去16,而正常的十進(jìn)制加法進(jìn)位應(yīng)該使個(gè)位數(shù)被減去10,所以需通過(guò)加“6”操作補(bǔ)上多減去的“6”。
(2)調(diào)整BCD碼運(yùn)算結(jié)果的“十位”
若累加器A中運(yùn)算結(jié)果的“十位”(即高4位)數(shù)大于9(非BCD碼)或累加器A中“十位”產(chǎn)生進(jìn)位(進(jìn)位標(biāo)志位(CY)=1),則在累加器A的“十位”上加“6”。這樣做的原因與步驟(1)相似。
【例3-34】DA指令舉例。
以下程序段可以完成壓縮BCD碼的加法運(yùn)算88H+02H=90H。
3.減法指令SUBB
SUBB指令將累加器A中的數(shù)減去源操作數(shù)和進(jìn)位標(biāo)志位CY,并將減法結(jié)果存入累加器A,其運(yùn)算結(jié)果會(huì)影響PSW中的CY、OV、AC和P標(biāo)志位。SUBB指令對(duì)標(biāo)志位的影響如下:當(dāng)減法的第7位有借位時(shí),則進(jìn)位標(biāo)志位CY被置1,否則被清0;如果減法結(jié)果的第3位有借位,則輔助進(jìn)位標(biāo)志位AC被置1,否則被清0;如果減法結(jié)果的第6位和第7
位的借位情況不一致,則溢出標(biāo)志位被置1,否則被清0;運(yùn)算結(jié)束時(shí),奇偶標(biāo)志位P的值由累加器A中的數(shù)決定,若累加器A中的值以二進(jìn)制表示后,其中“1”的個(gè)數(shù)為奇數(shù)個(gè),則(P)=1,否則(P)=0。
【例3-35】SUBB指令舉例。確定下段程序執(zhí)行后,累加器A和PSW的值。
解:運(yùn)行結(jié)果是(A)=8CH、(PSW)=0C1H(即P=1、OV=0、AC=1和CY=1)。
4.加1指令I(lǐng)NC和減1指令DEC
INC指令和DEC指令分別對(duì)指令中唯一的操作數(shù)進(jìn)行加1和減1操作,并將結(jié)果送回操作數(shù)。除了“INC A”和“DEC A”指令將影響奇偶標(biāo)志位P以外,其他INC和DEC指令均不影響任何標(biāo)志位。注意:這里所說(shuō)的“不影響”是指標(biāo)志位原來(lái)的狀態(tài)保持不變。另外,“INC DPTR”指令進(jìn)行16位數(shù)加1操作,該指令執(zhí)行時(shí),先將DPL加1,若產(chǎn)生進(jìn)位,則將DPH加1,并且DPL加1和DPH加1產(chǎn)生的進(jìn)位不影響AC和CY。另外,無(wú)“DEC DPTR”指令。
還需特別注意的是:若用INC和DEC修改單片機(jī)并行I/O口(P0~P3)的引腳狀態(tài),如指令“INC P0”,則指令執(zhí)行時(shí)采用的是“讀-修改-寫”方式,即先從端口的輸出鎖存器(而不是端口的引腳)讀取端口數(shù)據(jù),然后修改該數(shù)據(jù)(INC指令進(jìn)行加1操作,DEC指令進(jìn)行減1操作),最后將修改結(jié)果輸出到端口引腳上。
5.乘法指令MUL
乘法指令的格式見表3-7,乘法的被乘數(shù)和乘數(shù)均為8位無(wú)符號(hào)數(shù),且默認(rèn)存放在累加器A和寄存器B中。乘積為16位無(wú)符號(hào)數(shù),其低8位存放于累加器A中,高8位存放在寄存器B中,如圖3-2所示。
圖3-2乘法指令示意圖
乘法指令對(duì)標(biāo)志位的影響為:若乘積大于0FFH,則溢出標(biāo)志位OV被置1,否則被清0;進(jìn)位標(biāo)志位總會(huì)被乘法指令清0。
6.除法指令DIV
除法指令的格式見表3-7。與乘法指令相似,除法指令的被除數(shù)和除數(shù)均為8位無(wú)符號(hào)數(shù),被除數(shù)默認(rèn)放在累加器A中,除數(shù)默認(rèn)放在寄存器B中。除法的商和余數(shù)均為8位無(wú)符號(hào)數(shù),分別存于累加器A中和寄存器B中,如圖3-3所示。
圖3-3除法指令示意圖
除法指令對(duì)標(biāo)志位的影響:若除數(shù)不為0,則溢出標(biāo)志位OV和進(jìn)位標(biāo)志位CY均被清0;若除數(shù)為0,則溢出標(biāo)志位(OV)被置為1,且累加器A和寄存器B的值是不確定的。