好吧, 我還是用中文講解吧
假設一個數值 12345678H 要被 1000H 除
除數: 1000H
被除數 12345678H
那首先你要先對 00001234H 作除法
也就是:
MOV AX,1234H
MOV DX,0000H
DIV 1000H
之後可以在 AX 取得商, DX取得餘數
把這個AX的商放在存放結果內存的雙字組的高位中
DX就不要去動它了, 把它放在DX 是因為第一次除法後, 餘數就為第二次除法的高位數
接下來就把5678H 放在AX中,
然後再做一次 DIV 1000H
這時候得到的商還是在AX中, 把這個商放到存放結果內存的雙字組的低位中
餘數DX 就放在內存中存放餘數的地方
做法就好像我們小學時候學的除法
1000H)-------------
)12345678H
第一次除的時候是1234H/1000H 得商1 餘234H
第二次除的時候是 2345H/1000H 得商2 餘345H..依此類推
具體實現如下
ASSUME DS:DATA, CS:CODE
DATA SEGMENT
DW 1000H
DD 12345678H,0H
DW ?
DATA ENDS
;------------------------------------------
;00 11 | 22 33 44 55 | 66 77 88 99 | AA BB
;------------------------------------------
CODE SEGMENT
START: MOV AX,DATA
MOV DS,AX
MOV BX,0
MOV CX,[BX] ;被除數
MOV AX,[BX+4] ;被除數 1234H
MOV DX,0 ;DX = 0
DIV CX ;00001234H / 1000H
MOV [BX+8],AX ;商放入存商數的高位
MOV AX,[BX+2] ;被除數 5678H
DIV CX ;DX = 234H, 所以整個是 2345678H / 1000H
MOV [BX+6],AX ;商放入存商數的低位
MOV [BX+0AH],DX ;餘放入存餘數的地方
MOV AX, 4C00H
INT 21H
CODE ENDS
END START