絮飞 发表于 2011-12-5 09:59:45

求解汇编视频实验四第三小题解释

实验4
(3) 下面的程序的功能是将“mov ax,4c00h”之前的指令复制到内存0:200处,补全程序。上机调试,跟踪运行结果。
assume cs:code
code segment
     mov ax,code  ;code为所填写的数据
     mov ds,ax
     mov ax,0020h
     mov es,ax
 
     mov bx,0
     mov cx,18h   ;18h为所填写的数据
s:   mov al,
     mov es:,al
     inc bx
     loop s
 
     mov ax,4c00h
     int 21h
code ends
end
 
提示:
1.因为题目的要求是把代码段内的指令当作数据,复制到目的地址。所以,源数据段ds和代码段cs相同,通过 mov ax,code/mov ds,ax ('/'符号是指两条指令的分隔)来设置源数据段。
2.可以先假设要复制8位数据(因为我们肉眼就可以看出此程序的长度不可能大于0ffh个字节)的字节数(如:10h),把程序补全,以便通过编译。这时我们以准确的第一空所填内容code与假想的第二空内容10h将程序补充完整并将其编译、连接、运行,接着进行DEBUG,在DEBUG时我们可用R命令查看CX的值,这时我们可以看到CX的值为1D,由此我们可以算出该程序的长度=18h,之所以减5是为了满足题目的要求(因为mov ax,4c00h/int 21h这两条指令的长度等于5)



我不明白的地方子在于 debug 我们编写的程序进去之后,用 “-r cx” 查看出来CX就是我们代码的长度吗?不理解。

Coing 发表于 2013-2-26 16:37:32

听大神说好像是这样的:

Coing 发表于 2013-2-26 16:38:24

你有一个程序,里面包含cx控制的loop循环,这是你赋予的cx的值作为循环次数,但是在程序还没有最后得到运行之前,cx的值不会变成你赋予的值,而是它原有的某个值。就像还没有开始施工的建筑设计图纸,你赋予的楼的样子是这样,但是没有盖上之前它还只是图像。而且你用debug加载的应该是编译连接之后的可执行文件*.exe,同样还没有运行。所以你可以用r命令查看到cx的值,其实此时的cx就是默认的程序的长度了。一旦你开始用t命令、g命令或者p命令运行给cx赋值的那个指令了,那cx的值就被循环次数覆盖了。希望你能明白。

Coing 发表于 2013-2-26 16:42:03

我刚开始也不懂,前面我看你的提示1才理解,后面我网上查了下,应该是这样理解,在上面我回复的

Coing 发表于 2013-2-26 16:47:02

r 命令查看,改变cpu寄存器的内容。

:$ 前面我发了那么多帖子是因为我还不怎么会发

小小小小鱼 发表于 2013-3-3 02:41:57

刚开始执行程序 时候 CX 的值= 程序~(不是源程序)占用的字节长度
页: [1]
查看完整版本: 求解汇编视频实验四第三小题解释