微機(jī)原理與接口技術(shù)課件:第3章_3 加1指令I(lǐng)NC(單操作數(shù)指令)_第1頁
微機(jī)原理與接口技術(shù)課件:第3章_3 加1指令I(lǐng)NC(單操作數(shù)指令)_第2頁
微機(jī)原理與接口技術(shù)課件:第3章_3 加1指令I(lǐng)NC(單操作數(shù)指令)_第3頁
微機(jī)原理與接口技術(shù)課件:第3章_3 加1指令I(lǐng)NC(單操作數(shù)指令)_第4頁
微機(jī)原理與接口技術(shù)課件:第3章_3 加1指令I(lǐng)NC(單操作數(shù)指令)_第5頁
已閱讀5頁,還剩33頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、格式:INC reg/mem功能:類似于C語言中的+操作:對指定的操作數(shù)加1 例: INC AL INC SI INC BYTE PTRBX+4注:本指令不影響CF標(biāo)志。3) 加1指令I(lǐng)NC(單操作數(shù)指令)1ADD/ADC對條件標(biāo)志位(CF/OF/ZF/SF)的影響:CF位表示無符號數(shù)相加的溢出。OF位表示帶符號數(shù)相加的溢出。1 結(jié)果為負(fù)0 否則SF=1 結(jié)果為00 否則ZF=1 和的最高有效位有向高位的進(jìn)位0 否則CF=1 兩個操作數(shù)符號相同,而結(jié)果符號與之相反0 否則OF=2(1) 不考慮借位的減法指令SUB 格式: SUB dest, src 操作: dest(dest)-(src)注:

2、1.源和目的操作數(shù)不能同時為存儲器操作數(shù) 2.立即數(shù)不能作為目的操作數(shù)指令例子: SUB AL,60H SUB BX+20H,DX SUB AX,CX2. 減法指令3SBB指令主要用于多字節(jié)的減法。格式: SBB dest, src操作: dest(dest)-(src)-(CF)指令例子: SBB AX,CX SBB WORD PTRSI,2080H SBB SI,DX(2) 考慮借位的減法指令SBB4例:x、y、z均為32位數(shù),分別存放在地址為X, X+2;Y,Y+2;Z,Z+2的存儲單元中,用指令序列實現(xiàn)wx+y+24-z,結(jié)果放在W, W+2單元中。 MOV AX, X MOV DX,

3、 X+2 ADD AX, Y ADC DX, Y+2 ; x+y ADD AX, 24 ADC DX, 0 ; x+y+24 SUB AX, Z SBB DX, Z+2 ; x+y+24-z MOV W, AX MOV W+2, DX ; 結(jié)果存入W, W+2單元5作用類似于C語言中的”操作符。格式:DEC opr 操作:opr(opr)-1指令例子: DEC CL DEC BYTE PTRDI+2 DEC SI (3) 減1指令DEC6格式: NEG opr操作: opr 0-(opr)對一個操作數(shù)取補(bǔ)碼相當(dāng)于用0減去此操作數(shù),故利用NEG指令可得到負(fù)數(shù)的絕對值。例:若(AL)=0FCH,則

4、執(zhí)行 NEG AL后, (AL)=04H,CF=1本例中,0FCH為-4的補(bǔ)碼,執(zhí)行求補(bǔ)指令后,即得到4(-4的絕對值)。(4) 求補(bǔ)指令NEG7SUB/SBB對標(biāo)志位(CF/OF/ZF/SF)的影響 CF=1表示無符號數(shù)減法溢出。 OF=1表示帶符號數(shù)減法溢出。NEG指令對CF/OF的影響: CF:操作數(shù)為0時,求補(bǔ)的結(jié)果使CF=0,否則CF=1。 OF:字節(jié)運(yùn)算對-128求補(bǔ)或字運(yùn)算對-32768求補(bǔ)時OF=1, 否則OF=0。1 被減數(shù)的最高有效位有向高位的借位0 否則CF=1 兩個操作數(shù)符號相反,而結(jié)果的符號與減數(shù)相同0 否則OF=8格式: CMP dest, src操作: (dest

5、)-(src)CMP也是執(zhí)行兩個操作數(shù)相減,但結(jié)果不送目標(biāo)操作數(shù),其結(jié)果只反映在標(biāo)志位上。指令例子: CMP AL,0AH CMP CX,SI CMP DI,BX+03(5) 比較指令CMP9根據(jù)標(biāo)志位來判斷比較的結(jié)果1)根據(jù)ZF判斷兩個數(shù)是否相等。若ZF=1,則兩數(shù)相等。2)若兩個數(shù)不相等,則分兩種情況考慮: 比較的是兩個無符號數(shù) 若CF=0,則destsrc; 若CF=1,則destsrc。 比較的是兩個有符號數(shù) 若OFSF=0,則destsrc; 若OFSF=1,則destsrc。10比較指令在使用時,一般在其后緊跟一條條件轉(zhuǎn)移指令,判斷比較結(jié)果的轉(zhuǎn)向。舉例:比較AL、BL、CL中帶符號

6、數(shù)的大小,將 最小數(shù)放在AL中。程序: CMP AL,BL ;AL和BL比較 JNG BBB ;若ALBL,則轉(zhuǎn) XCHG AL,BL ;若ALBL,則交換 BBB: CMP AL,CL ;AL和CL比較 JNG CCC ;若ALCL,則轉(zhuǎn) XCHG AL,CL ;若ALCL,則交換 CCC: HLT11進(jìn)行乘法時:8位*8位16位乘積 16位*16位32位乘積(1) 無符號數(shù)的乘法指令MUL(MEM/REG)格式: MUL src操作:字節(jié)操作數(shù) (AX) (AL) (src) 字操作數(shù) (DX, AX) (AX) (src)指令例子: MUL BL ;(AL)(BL),乘積在AX中 MUL

7、 CX ;(AX)(CX),乘積在DX,AX中 MUL BYTE PTRBX3. 乘法指令12格式與MUL指令類似,只是要求兩操作數(shù)均為有符號數(shù)。指令例子: IMUL BL ;(AX)(AL)(BL) IMUL WORD PTRSI ;(DX,AX)(AX)(SI+1SI) (2) 有符號數(shù)乘法指令I(lǐng)MUL注意:MUL/IMUL指令中 AL(AX)為隱含的乘數(shù)寄存器; AX(DX,AX)為隱含的乘積寄存器; SRC不能為立即數(shù); 除CF和OF外,對其它標(biāo)志位無定義。13乘法指令對CF/OF的影響:00 乘積的高一半為零11 否則MUL指令: CF/OF =00 乘積的高一半是低一半的符號擴(kuò)展1

8、1 否則 IMUL指令: CF/OF =例:(AL) = A5H(-5B),(BL) = 11H (1) IMUL BL ; (AX) (AL)(BL) ; A511 -5B11=-060B F9F5 ; (AX) = F9F5H CF=OF=1 (2) MUL BL ; (AX) (AL)(BL) ; A511= 0AF5 ; (AX) = 0AF5H CF=OF=1 144. 除法指令進(jìn)行除法時:16位/8位8位商 32位/16位16位商對被除數(shù)、商及余數(shù)存放有如下規(guī)定: 被除數(shù) 商余數(shù)字節(jié)除法 AX AL AH 字除法 DX:AX AX DX15格式: DIV src操作:字節(jié)操作 (A

9、L) (AX) / (SRC) 的商 (AH) (AX) / (SRC) 的余數(shù) 字操作 (AX) (DX, AX) / (SRC) 的商 (DX) (DX, AX) / (SRC) 的余數(shù)指令例子: DIV CL DIV WORD PTRBX注:若除數(shù)為零或AL中商大于FFH,(或AX中商大于FFFFH),則CPU產(chǎn)生一個類型0的內(nèi)部中斷。(1) 無符號數(shù)除法指令DIV16(2) 有符號數(shù)除法指令I(lǐng)DIV格式: IDIV src操作與DIV類似。商及余數(shù)均為有符號數(shù),且余數(shù)符號總是與被除數(shù)符號相同。注意: 對于DIV/IDIV指令 AX(DX,AX)為隱含的被除數(shù)寄存器。 AL(AX)為隱含

10、的商寄存器。 AH(DX)為隱含的余數(shù)寄存器。 src不能為立即數(shù)。 對所有條件標(biāo)志位均無定義。17除法運(yùn)算要求被除數(shù)字長是除數(shù)字長的兩倍,若不滿足則需對被除數(shù)進(jìn)行擴(kuò)展,否則產(chǎn)生錯誤。對于無符號數(shù)除法擴(kuò)展,只需將AH或DX清零即可。對有符號數(shù)而言,則是符號位的擴(kuò)展??墒褂们懊娼榻B過的符號擴(kuò)展指令CBW和CWD關(guān)于除法操作中的字長擴(kuò)展問題18例: 寫出34H25H的程序段。MOV AL,34H MOV BL,25H CBW ; AL的符號擴(kuò)展到AH DIV BL ; 0034H25H,結(jié)果為 ; (AH)=0FH, (AL)=01H195.BCD碼運(yùn)算的十進(jìn)制調(diào)整指令專用于對BCD碼運(yùn)算的結(jié)果進(jìn)

11、行調(diào)整包括:DAA、AAA、DAS、AAS、AAM、AAD均為隱含尋址,隱含的操作數(shù)為AL和AH為何要對BCD碼的運(yùn)算結(jié)果進(jìn)行調(diào)整? BCD碼本質(zhì)上是十進(jìn)制數(shù),即應(yīng)遵循逢十進(jìn)一的規(guī)則。而計算機(jī)是按二進(jìn)制(十六進(jìn)制)進(jìn)行運(yùn)算,并未按十進(jìn)制規(guī)則進(jìn)行運(yùn)算。201)加法的十進(jìn)制調(diào)整指令(1)非壓縮BCD碼加法調(diào)整AAA本指令對在AL中的由兩個未組合的BCD碼相加后的結(jié)果進(jìn)行調(diào)正,得到一個正確的未組合的BCD碼。AAA指令只影響AF和CF,其余標(biāo)志無定義。AAA指令應(yīng)緊跟在ADD或ADC指令之后。21如果AL的低4位9AF=1,則: AL(AL)+6,(AH)(AH)+1,AF1 AL(AL)0FH)

12、CFAF否則AL(AL)0FHAAA指令的操作如下:22調(diào)整原理:先看一個例子 計算89 0000 1000 見右式 +0000 1001 0001 0001 11 結(jié)果應(yīng)為17,而計算機(jī)相加為11,原因在于運(yùn)算過程中,如遇到低4位往高4位產(chǎn)生進(jìn)位時(此時AF=1)是按逢十六進(jìn)一的規(guī)則,但BCD碼要求逢十進(jìn)一,因此只要產(chǎn)生進(jìn)位,個位就會少6,這就要進(jìn)行加6調(diào)正。這個1代表了16,而實際上僅應(yīng)為10,即多進(jìn)了6。 23實際上當(dāng)?shù)?位的結(jié)果9(即AF之間)時,也應(yīng)進(jìn)行加6調(diào)正。(原因是逢十沒有進(jìn)位,故用加6的方法強(qiáng)行產(chǎn)生進(jìn)位。) 如對上例的結(jié)果進(jìn)行加6: 0001 0001 11 + 0000 0

13、110 6 0001 0111 17 結(jié)果正確。24例2:有兩個字符串形式的十進(jìn)制數(shù),2658和 3619,求二者之和。即2658+3619=? 由題意知,被加數(shù)和加數(shù)的每一位都以ASCII碼形式存放在內(nèi)存中。假定二數(shù)在內(nèi)存中均是低位在前,高位在后,另留出5個單元存放相加的結(jié)果。內(nèi)存中數(shù)據(jù)存放形式見下頁圖。2536H32H39H31HSTRING1STRING238H35H36H33H被加數(shù)加數(shù)數(shù)據(jù)段85629163SUM結(jié)果.26程序段為: LEA SI,STRING1 ;STRING1偏移地址送SI LEA DI,STRING2 ;STRING2偏移地址送DI LEA BX,SUM ;SU

14、M偏移地址送BX MOV CX,4 ;循環(huán)4次 CLC ;清進(jìn)位標(biāo)志AGAIN:MOV AL,SI ADC AL,DI ;帶進(jìn)位加 AAA ;未壓縮BCD碼調(diào)正 MOV BX,AL ;結(jié)果存入SUM INC SI ;調(diào)整指針 INC DI INC BX DEC CX ;循環(huán)計數(shù)器減1 JNZ AGAIN ;若未處理完,則轉(zhuǎn)AGAIN27 思考題: 1.根據(jù)程序?qū)懗鼋Y(jié)果SUM的值。 2.若最高位有進(jìn)位,程序如何修改? 3.從此例不難看出,用AAA指令也可對字符串形式的十進(jìn)制數(shù)加法進(jìn)行調(diào)整,所以它又被稱為加法的ASCII調(diào)正指令。為什么AAA指令既可對非壓縮BCD碼加法進(jìn)行調(diào)整,也可對ASCII碼

15、形式的十進(jìn)制數(shù)進(jìn)行調(diào)整?(注意AAA指令的第步)28(2)壓縮BCD碼加法調(diào)整DAA兩個壓縮BCD碼相加結(jié)果在AL中,通過DAA調(diào)整得到一個正確的壓縮BCD碼.指令操作(調(diào)整方法): 若AL的低4位9AF=1 則(AL)(AL)+6,AF1 若AL的高4位9CF=1 則(AL)(AL)+60H,CF1除OF外,DAA指令影響所有其它標(biāo)志。DAA指令應(yīng)緊跟在ADD或ADC指令之后。29例: 0100 1000 48H MOV AL,48H + 0111 0100 74H MOV BL,74H 1011 1100 BCH ADD AL,BL + 0110 0110 66H DAA 1 0010 0

16、010 1 22H (進(jìn)位) (進(jìn)位) 執(zhí)行ADD后,(AL)=BCH,高4位低4位均大于9,故DAA指令執(zhí)行加66H調(diào)整,最后結(jié)果為: (AL)=22H, CF=1, AF=130(1)非壓縮BCD碼減法的十進(jìn)制調(diào)正指令A(yù)AS 對AL中由兩個非壓縮的BCD碼相減的結(jié)果進(jìn)行調(diào)整。調(diào)整操作為: 若AL的低4位9或AF=1,則: AL(AL)-6,AH(AH)-1,AF1 AL(AL)0FH CFAF 否則:AL(AL)0FH2)減法的十進(jìn)制調(diào)整指令31舉例:16-8=? MOV AX,0106H 0000 0110 06 MOV BL,08H - 0000 1000 - 08 SUB AL,BL

17、 1111 1110 FE AAS - 0000 0110 - 06 1111 1000 F8 0000 1111 0F 0000 1000 08結(jié)果為:(AL)=08H,(AH)=0,CF=AF=132(2)壓縮BCD碼減法的十進(jìn)制調(diào)正指令DAS 對AL中由兩個壓縮BCD碼相減的結(jié)果進(jìn)行調(diào)整。調(diào)整操作為: 若AL的低4位9AF=1,則: AL(AL)-6, 且AF1 若AL的高4位9CF=1,則: AL(AL)-60H,且CF1 DAS對OF無定義,但影響其余標(biāo)志位。DAS指令要求跟在減法指令之后。333) 乘法的十進(jìn)制調(diào)正指令A(yù)AM 對AX中由兩個非壓縮BCD碼相乘的結(jié)果進(jìn)行調(diào)整。調(diào)整操作

18、為: (AL)/0AH, (AH)商,(AL)余數(shù)隱含的操作寄存器為AL和AH;AAM跟在MUL指令之后使用;影響標(biāo)志位PF、SF、ZF,其它無定義;用AAM可實現(xiàn)99的二-十進(jìn)制轉(zhuǎn)換。34例1:按十進(jìn)制乘法計算78=? 程序段如下:MOVAL,07H;(AL)=07HMOVCL,08H;(CL)=08HMULCL;(AX)=0038HAAM;(AH)=05H,(AL)=06H 所得結(jié)果為非壓縮的BCD碼。例2:把3AH轉(zhuǎn)換成等值的十進(jìn)制數(shù)。 MOV AL,3AH ;58 AAM ;(AH)=05H,(AL)=08H354) 除法的十進(jìn)制調(diào)正指令A(yù)AD對非壓縮BCD除法運(yùn)算進(jìn)行調(diào)整。調(diào)整操作為: (AL)(AH)0AH(AL) AH 0隱含的操作寄存器為AH,AL;AAD要在DIV指令之前使用

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論