《汇编语言(王爽)》(第八章、实验7寻址方式在结构化数据访问中的应用)学习笔记

注意对结果"divide overflow"的调试:被除数为16位时,除数高位移到dx中,低位移到ax中(注意在内存中数据的排列方式,先低位:

mov ax,[bx];在高位:mov dx,[bx+2];)

调试过程中要仔细,不能浮躁

assume cs:codesg,ds:datasg,ss:stacksg
datasg segment
db '1975','1976','1977','1978','1979','1980','1981','1982','1983'
db '1984','1985','1986','1987','1988','1989','1990','1991','1992'
db '1993','1994','1995'
dd 16,22,382,1356,2390,8000,16000,24486,50065,97497,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,15257,17800
datasg ends
table segment
db 21 dup ('yaar sumn ne ?? ')
table ends
stacksg segment
dw 0,0,0,0,0,0,0,0
stacksg ends
codesg segment
start:
mov ax,datasg
mov ds,ax
mov ax,table
mov es,ax
mov ax,stacksg
mov ss,ax
mov sp,10
mov bx,0
mov di,0
mov si,0
mov cx,21
s:
mov ax,[bx+0+di]
mov es:[si+0],ax
mov ax,[bx+2+di]
mov es:[si+2],ax
add bx,84
mov ax,[bx+0+di]
mov es:[si+5],ax
mov dx,[bx+2+di]
mov es:[si+7],dx
push ax
push dx
push di
mov dx,0
mov ax,di
mov di,2
div di
mov di,ax
add bx,84
mov ax,[bx+di]
mov es:[si+0ah],ax
pop di
pop dx
pop ax
div word ptr es:[si+0ah]
mov es:[si+0dh],ax
mov bx,0
add di,4
add si,10h
loop s
mov ax,4c00h
int 21h
codesg ends
end start

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值