实验10 编写子程序 2.解决除法溢出的问题
assume cs:code,ss:stack
stack segment
dw 8 dup (0)
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,10h
mov ax,4240h
mov dx,0fh
mov cx,0ah
call divdw
mov ax,4c00h
int 21h
divdw: ;子程序定义开始
push ax ;进栈,说明后边要用到。低16位先保存
mov ax,dx ;ax这时候的值是高16位
mov dx,0 ;dx置0是为了不影响下边余数位,使得被除数的高16位为0
div cx ;H/N
mov bx,ax ;ax,bx的值为商,即(int)H/N;dx的值为余数,即(rem)H/N
pop ax ;ax此时的值为L,即低16位
div cx ;L/N。注意,16位除法的时候,默认被除数的高16位在dx中,低16位在ax中
mov cx,dx
mov dx,bx
ret ;子程序定义结束
code ends
end start