一段陷入死循环的代码
assume cs:codesg, ss:stacksgdata 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'
; 表示21年的21个字符串
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
;表示21年公司总收入的21个dword数据
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,15257,17800
;表示21年公司雇员的21个word型数据
data ends
stacksg segment
db 16 dup (0)
stacksg ends
table segment
db 21 dup ('year summ ne ?? ')
table ends
codesg segment
start: mov ax,data
mov ds,ax
mov ax,table
mov es,ax
mov ax,stacksg
mov ss,ax
mov sp,16
mov bx,0
mov bp,0
mov si,0
mov di,168
mov cx,21
s0: push cx
push si
mov cx,4
s1: mov al,ds:
mov es:,al
inc bp
inc bx
loop s1
add si,84
mov byte ptr es:,' '
inc bx
mov ax,
mov es:,ax
mov ax,
mov es:,ax
add bx,4
mov byte ptr es:,' '
inc bx
mov ax,
mov es:,ax
add di,2
mov ax,es:
div byte ptr es:
mov ah,0
add bx,2
mov byte ptr es:,' '
inc bx
mov es:,ax
add bx,2
mov byte ptr es:,' '
inc bx
pop si
add si,4
pop cx
loop s0
mov ax,4c00H
int 21H
codesg ends
end start
在debug中,碰到loop s1时用p可以往下执行,但是碰到loop s0的时候用p就陷入死循环了。死活找不到问题,求解。 没有死循环啊,只是除法溢出了 人造人 发表于 2016-1-27 21:23
没有死循环啊,只是除法溢出了
怎么会溢出呀?? 发现问题了,应该用16位的除法,我用的8位。。。
页:
[1]