关于实验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)
CX为循环次数,肯定不会有疑问的,
下面继续,
假设循环次数不确定,那么 mov cx,?
?随便写个3,这样编译连接后,以便跟踪程序,
debug 程序全名后
-r 查看寄存器的情况,
-u 查看当前内存中的数据以汇编形式显示
重点 看 movax,4c00h 这条指令的偏移地址,
那么我们可以得知 这条指令之前的机器码的长度!
然后返回修改cx的值!
关于为何有的指令为3个字节,有的指令为2个字节,
这个我还不懂怎样计算,懂了后可以自己计算,
先学完在来研究指令编码格式
本帖最后由 demon 于 2011-7-9 16:03 编辑
汇编其实不难,
我自己的一点学习经验就是,
打开系统自带的计算器,因为进制需要换算,
记事本,遇到题目代码先写出来,然后在脑子里在跑一遍,大概什么结果
遇到问题想不通就debug下,或者验证下,
这样学起来,汇编真的不是难事! 我建议楼主还是多打开计算器算算,可能刚开始进制不习惯~~~多尝试 不是进制的方面的问题,我想问的是,我跟踪到MOV AX,4C00H时,IP为18H,我就是从这里得知的,但是,小甲鱼说是从CX得知的,我不懂 我不懂的是小甲鱼说什么=18h 本帖最后由 Mr.han 于 2011-7-9 22:20 编辑
寄存器CX中存放的数值应该表示这段汇编指令的长度。
又因为Mov ax,4c00h占3个字节,Int 21H占两个字节,所以要减5.
貌似应该这样解释,我也是新手。{:1_1:}
CX跟长度有关吗,大哥,CX有这么用过吗 Mr.han 发表于 2011-7-9 22:17 static/image/common/back.gif
寄存器CX中存放的数值应该表示这段汇编指令的长度。
又因为Mov ax,4c00h占3个字节,Int 21H占两个字节,所 ...
{:1_1:}正解!!
在刚刚加载的时候,CX的值代表了整个代码段的长度;
书上和视频都有说的,看仔细点:o
页:
[1]