实验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 @   houhaibushihai  阅读(245)  评论(0编辑  收藏  举报
编辑推荐:
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
阅读排行:
· 《HelloGitHub》第 108 期
· Windows桌面应用自动更新解决方案SharpUpdater5发布
· 我的家庭实验室服务器集群硬件清单
· C# 13 中的新增功能实操
· Supergateway:MCP服务器的远程调试与集成工具
点击右上角即可分享
微信分享提示