实验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

讲解视频

posted @ 2018-10-06 10:54  houhaibushihai  阅读(243)  评论(0编辑  收藏  举报