<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 8086指令系統(tǒng)---算術(shù)指令(一)

          8086指令系統(tǒng)---算術(shù)指令(一)

          作者: 時間:2016-11-27 來源:網(wǎng)絡(luò) 收藏


           ?、?43H-16H=2DH
              0100 0011     0100 0011   條件碼設(shè)置:CF=0
           ?。?0001 0110    + 1110 1010         OF=0
           --------------    --------------
              0010 1101    1← 0010 1101


            說明:機(jī)器作減法運(yùn)算時,先將減數(shù)求補(bǔ),然后轉(zhuǎn)化為加法運(yùn)算,所以實(shí)際上機(jī)器設(shè)置CF的方法是:最高有效位不產(chǎn)生進(jìn)位時,CF=1;最高有效位產(chǎn)生進(jìn)位時,CF=0。這和做減法時有借位CF=1,無借位CF=0是一致的。
            本例參加運(yùn)算的數(shù)無論是看作帶符號數(shù)還是無符號數(shù),運(yùn)算結(jié)果均有效。


           ?、?0C8H-66H=62H
              1100 1000     1100 1000   條件碼設(shè)置:CF=0
           ?。?0110 0110   + 1001 1010         OF=1
            --------------    ------------
              0110 0010    1← 0110 0010

            說明:如果是無符號數(shù)的運(yùn)算,被減數(shù)夠減無借位,所以CF置0,表明結(jié)果有效。如果操作數(shù)是帶符號數(shù),且被減數(shù)與減數(shù)符號相反,而結(jié)果符號與減數(shù)符號相同,所以O(shè)F置1,表明結(jié)果無效。

             ③ 54H-76H=0DEH
              0101 0100    0101 0100    條件碼設(shè)置:CF=1
             - 0111 0110   + 1000 1010          OF=0
             -------------    -------------
              1101 1110      1101 1110


            說明:如果是無符號數(shù)的運(yùn)算,本例中被減數(shù)<減數(shù),減運(yùn)算向高位有借位(或加運(yùn)算無進(jìn)位),則CF置0,表明結(jié)果無效。如果是帶符號數(shù)的運(yùn)算,同符號數(shù)相減,OF置0,結(jié)果有效。

             ④ 4BH-0B6H=0DEH
              0100 1011    0100 1011    條件碼設(shè)置:CF=1
             - 1011 0110   + 0100 1010          F=1
             ---------------    -----------
              1001 0101      1001 0101

            說明:如果是無符號數(shù)的運(yùn)算,本例中被減數(shù)<減數(shù),減運(yùn)算向高位有借位(或加運(yùn)算無進(jìn)位),則CF置0,表明結(jié)果無效。如果是帶符號數(shù)的運(yùn)算,不同符號數(shù)相減,且結(jié)果符號與減數(shù)符號相同,OF置1,結(jié)果也是無效的。

            例分析下列程序的執(zhí)行情況:
            
                  DATA_A   DD   62562FAH
                  DATA_B   DD   412963BH
                  RESULT   DD   ?
                   …    …   …
                  MOV     AX, WORD PTR DATA_A   ; (AX)=62FAH
                  SUB    AX, WORD PTR DATA_B   ; sub 963BH from AX
                  MOV    WORD PTR RESULT, AX   ; save the result
                  MOV    AX, WORD PTR DATA_A+2  ; (AX)=0625H
                  SBB    AX, WORD PTR DATA_B+2  ; sub 0412H with borrow
                  MOV    WORD PTR RESULT, AX   ; save the result

            答:SUB指令執(zhí)行后,(AX)= 62FAH-963BH=0CCBFH,CF=1(有借位)。執(zhí)行SBB指令后,(AX)= 625H-412H-1=212H,CF=0,OF=0,因此,保存于RESULT的結(jié)果數(shù)據(jù)為0212CCBFH。

           3 乘法指令

            MUL  src  無符號數(shù)乘法(unsigned multiple)
            IMUL src  帶符號數(shù)乘法(signed multiple)
            字節(jié)操作: (AX) ← (AL)×(src)
            字操作:  (DX, AX) ← (AX)×(src)

            MUL和IMUL指令的區(qū)別僅在于操作數(shù)是無符號數(shù)還是帶符號數(shù),它們的共同點(diǎn)是,指令中只給出源操作數(shù)src,它可以使用除立即數(shù)方式以外的任一種尋址方式。目的操作數(shù)是隱含的,它只能是累加器(字運(yùn)算為AX,字節(jié)運(yùn)算為AL)。隱含的乘積寄存器是AX或DX(高位)和AX(低位)。

            乘法指令只影響CF和OF,其它條件碼位無定義。無定義是指指令執(zhí)行后,條件碼位的狀態(tài)不確定,因此它們是無用的。

            MUL指令的條件碼設(shè)置為:
            CF OF= 0 0 乘積的高一半為0(字節(jié)操作的(AH)或字操作的(DX))
            CF OF= 1 1 乘積的高一半不為0

            這樣的條件碼設(shè)置可以指出字節(jié)相乘的結(jié)果是8位(CF=0)還是16位(CF=1),字相乘的結(jié)果是16位(CF=0)還是32位(CF=1)。

            IMUL指令的條件碼設(shè)置為:
            CF OF= 0 0 乘積的高一半為低一半的符號擴(kuò)展
            CF OF= 1 1 其他情況

            符號擴(kuò)展是指做字節(jié)乘法時,乘積低8位的最高位為0,高8位也擴(kuò)展為0,或者低8位的最高位為1,高8位也擴(kuò)展為1的情況。對兩個字相乘,符號擴(kuò)展是指乘積的低16位的最高位為0,高16位也擴(kuò)展為0,或者低16位的最高位為1,高16位也擴(kuò)展為1的情況。

          本文引用地址:http://www.ex-cimer.com/article/201611/322192.htm

           例無符號數(shù)乘法 

              ; from the data segment
              DATA1  DB  25H
              DATA2  DB  65H
              RESULT DW ?
              ; from the code segment
                MOV   AL,DATA1
                MOV   BL,DATA2
                MUL   BL        ; register addressing mode
                MOV   RESULT,AX
              or
                MOV   AL,DATA1
                MUL   DATA2       ; direct addressing mode
                MOV   RESULT,AX
              or
                MOV   AL,DATA1
                MOV   SI,OFFSET DATA2
                MUL   BYTE PTR [SI]   ;register indirect addressing mode
                MOV   RESULT,AX

            本例25H×65H=0E99H,高16位不為0,所以CF=1,OF=1。
           
           
            例  

              DATA3  DW  2378H
              DATA4  DW  2F79H
              RESULT1 DW  2 DUP(?)
              …    …
                MOV   AX, DATA3   ; load first operand into AX
                IMUL   DATA4     ; multiply it by the second operand
                MOV   RESULT1, AX  ; store the lower word result
                MOV   RESULT1+2, DX ; store the higher word result

            本例2378H×2F79H=0693 CBB8H,即(DX)=0693H,(AX)=0CBB8H。因?yàn)楦?6位不是低16位的符號擴(kuò)展,所以條件碼設(shè)置為CF=1,OF=1。


          上一頁 1 2 下一頁

          關(guān)鍵詞: 8086指令系統(tǒng)算術(shù)指

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();