skylove1233 发表于 2017-9-10 00:04:06

关于检测点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:21

我这里调试了下是对的,你再进行编译链接调试看看。

skylove1233 发表于 2017-9-10 11:09:29

丶忘却的年少o 发表于 2017-9-10 10:15
我这里调试了下是对的,你再进行编译链接调试看看。

你把SP指向18了吗?我指向36也是正确的,但指向18就错误了

丶忘却的年少o 发表于 2017-9-10 12:07:41

skylove1233 发表于 2017-9-10 11:09
你把SP指向18了吗?我指向36也是正确的,但指向18就错误了

我是直接复制你的程序的。就是36。18我试了是会错误,我的理解是因为单步也是一个指令操作,所有的操作会保存在栈中用于下一次执行的恢复。所以会覆盖掉一些数据吧。(这是我自己的理解)
页: [1]
查看完整版本: 关于检测点6.1