关于检测点6.1
检测点6.1是个填空题,要求程序实现依次用内存0:0--0:15单元中的内容改写程序中的数据,数据的传送用栈来进行。栈空间设置在程序内。程序如下:assume cs:codesg
codesg segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
dw 0,0,0,0,0,0,0,0,0,0 ;10个字单元用作栈空间
start:mov ax,cs
mov ss, ax
mov sp, 24h
mov ax, 0
mov ds, ax
mov bx, 0
mov cx, 8
s: push
pop cs:
add bx, 2
loop s
mov ax, 4c00h
int 21h
codesg ends
end start
由于在咱们论坛看到一个帖子,说这个程序其实只用到了栈空间的一个字单元,则把SS:SP指向12H也就是18处,应该也是可以的,然后我把数字改了之后debug了一下,如下图:我想问下,为什么这里d 0:0 f和d 076a(cs):0 f的值有几位不相等
我这里调试了下是对的,你再进行编译链接调试看看。
丶忘却的年少o 发表于 2017-9-10 10:15
我这里调试了下是对的,你再进行编译链接调试看看。
你把SP指向18了吗?我指向36也是正确的,但指向18就错误了 skylove1233 发表于 2017-9-10 11:09
你把SP指向18了吗?我指向36也是正确的,但指向18就错误了
我是直接复制你的程序的。就是36。18我试了是会错误,我的理解是因为单步也是一个指令操作,所有的操作会保存在栈中用于下一次执行的恢复。所以会覆盖掉一些数据吧。(这是我自己的理解)
页:
[1]