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

讲解视频

转载于:https://www.cnblogs.com/houhaibushihai/p/9746856.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值