;divdw
;进行不会溢出的除法运算
;(ax)=dword型数据的低16位,(dx)=dword型数据的高16位,(cx)=除数
;返回:(dx)=结果的高16位,(ax)=结果的低16位,(cx)=余数
assume cs:codesg,ss:stack
stack segment
db 16 dup (0)
stack ends
codesg segment
start: mov ax,stack
mov ss,ax
mov sp,10h
mov ax,4240h
push ax
mov dx,000fh
push dx
mov cx,0ah
push cx
call divdw
mov ax,4c00h
int 21h
divdw: push bp
mov bp,sp
mov ax,dx
mov dx,0
div cx
mov bx,ax ;保存高16位的商到bx
mov ax,[bp+8]
div cx
mov cx,dx ;返回时,cx放余数
mov dx,bx ;返回时,高16位商放到dx,ax的值正好是商的低16位
pop bp
ret 6
codesg ends
end start
;与答案几乎一样,呵呵
- [游客] 你说的就是传说中的易语言么?(*^__^*) 嘻嘻…… 03/22 21:44
- [taotling] 你啊,肯定是太贪快,所以细节上的东西没注意。。。。 来晚了,报个到。 04/09 23:46
- [wdm] mov es:[di],cx ;原来是mov es:[di],cl mov es:[ 04/09 15:11
- [wdm] 看到内存b850:0006处的变化真的很奇怪 ============= 数据必然都是你些进入的 04/09 14:41
- [wdm] 我不明白为什么sp=4的时候,用t单步就会错?明明堆栈还有2个字的空间啊?! --------- 04/09 14:34
- [wdm] 书里哪里说过吗?还有没什么会出现这个情况?按理说,堆栈不是还有2个字的位置吗? ========= 04/09 14:30
- [hantangtianxia] debug跟踪的问题 如果直接运行或debug g命令 执行,不会出问题 04/08 23:17
- [rsice] wdm:博主看看这里的sp的值,mov dx,0000后的T命令的时候,你的sp只剩下4了,记得前面 04/08 23:12
- [游客] 功能子程序dtoc中应该添加保护现场和恢复现场语句序列! 答:确实没有保护现场,我觉得可能下面的 04/08 21:18
- [游客] 将行偏移添加到了段地址中?!应该把行、列偏移都放在偏移地址寄存器di中。 答:是这样的,我是把行 04/08 21:17