milorguan 发表于 2011-7-9 15:32:51

关于实验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为所填写的数据      这里我不懂为什么是18H,下面的解释
s:   mov al,                                          ;说看CX,为什么对比CX得 出答案
   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)



demon 发表于 2011-7-9 15:56:41

CX为循环次数,肯定不会有疑问的,
下面继续,
假设循环次数不确定,那么 mov cx,?   
?随便写个3,这样编译连接后,以便跟踪程序,
debug 程序全名后
-r 查看寄存器的情况,
-u 查看当前内存中的数据以汇编形式显示
重点 看   movax,4c00h 这条指令的偏移地址,
那么我们可以得知 这条指令之前的机器码的长度!
然后返回修改cx的值!

关于为何有的指令为3个字节,有的指令为2个字节,
这个我还不懂怎样计算,懂了后可以自己计算,
先学完在来研究指令编码格式

demon 发表于 2011-7-9 16:01:21

本帖最后由 demon 于 2011-7-9 16:03 编辑

汇编其实不难,
我自己的一点学习经验就是,
打开系统自带的计算器,因为进制需要换算,
记事本,遇到题目代码先写出来,然后在脑子里在跑一遍,大概什么结果
遇到问题想不通就debug下,或者验证下,
这样学起来,汇编真的不是难事!

bjhrwzh 发表于 2011-7-9 18:11:34

我建议楼主还是多打开计算器算算,可能刚开始进制不习惯~~~多尝试

milorguan 发表于 2011-7-9 20:12:07

不是进制的方面的问题,我想问的是,我跟踪到MOV AX,4C00H时,IP为18H,我就是从这里得知的,但是,小甲鱼说是从CX得知的,我不懂

milorguan 发表于 2011-7-9 20:13:54

我不懂的是小甲鱼说什么=18h

Mr.han 发表于 2011-7-9 22:17:07

本帖最后由 Mr.han 于 2011-7-9 22:20 编辑

寄存器CX中存放的数值应该表示这段汇编指令的长度。
又因为Mov ax,4c00h占3个字节,Int 21H占两个字节,所以要减5.
貌似应该这样解释,我也是新手。{:1_1:}

milorguan 发表于 2011-7-10 14:36:07

CX跟长度有关吗,大哥,CX有这么用过吗

demon 发表于 2011-7-10 16:00:42

Mr.han 发表于 2011-7-9 22:17 static/image/common/back.gif
寄存器CX中存放的数值应该表示这段汇编指令的长度。
又因为Mov ax,4c00h占3个字节,Int 21H占两个字节,所 ...

{:1_1:}正解!!

linha0 发表于 2011-7-10 16:12:21

在刚刚加载的时候,CX的值代表了整个代码段的长度;

书上和视频都有说的,看仔细点:o
页: [1]
查看完整版本: 关于实验4的疑问