|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
assume cs:code
code segment
start:
mov ax,4247h
mov dx,000fh
mov cx,0ah
call divdw
mov ax,4c00h
int 21h
divdw:
mov bx,ax
mov ax,dx
mov dx,0 ;; 以上三步则是 计算 H/N, 之后ax=int(H/N), dx=rem(H/N)
div cx
; 因为当前ax中存放的是 int(H/N),相当于存放的是高位的数据
; 所以下面这3个 xor 操作是将高位的值放到bx中,然后再将 L 的数据放到ax中
xor ax,bx ; 交换 ax和bx 的值
xor bx,ax ; 交换 ax和bx 的值
xor ax,bx ; 交换 ax和bx 的值
; 交换的目的其实只是为了减少空间的使用,不使用多余的内存来存储数据
div cx
; 这一步之后,存放的是 ax=(rem(H/N)*65536+L)/N 的结果
; dx=余数
; 将高位的结果放到dx中
xor dx,bx
xor bx,dx
xor dx,bx
mov cx,bx ; 将余数存入cx
ret
code ends
end start
|
|