检测点3.1求助
(1)在DEBUG中,用 "D 0:0 lf" 查看内存,结果如下:0000:0000 70 80 F0 30 EF 60 30 E2-00 80 80 12 66 20 22 60
0000:0010 62 26 E6 D6 CC 2E 3C 3B-AB BA 00 00 26 06 66 88
下面的程序执行前,AX=0,BX=0,写出每条汇编指令执行完后相关寄存器中的值
mov ax,1
mov ds,ax
mov ax,ax= 2662H
mov bx,bx= E626H
mov ax,bx ax= E626H
mov ax,ax= 2662H
mov bx,bx= D6E6H
add ax,bx ax= FD48H
add ax,ax= 2C14H
mov ax,0 ax= 0
mov al,ax= 00e6H
mov bx,0 bx= 0
mov bl,bx= 0026H
add al,bl ax= 000CH
2) 内存中的情况如图3.6所示
各寄存器的初始值:cs=2000h,ip=0,ds=1000h,ax=0,bx=0;
① 写出CPU执行的指令序列(用汇编指令写出)。
② 写出CPU执行每条指令后,CS、IP和相关寄存器的数值。
③ 再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?
指令序列:mov ax,6622h ;ax=6622h 执行后cs:ip指向2000:3执行前cs:ip指向2000:0
jmp 0ff0:0100 ; CS=0ff0 ip= 0100 指向0ff0*16+100=0ff00+100=10000h cs:ip指向0ff0:0100
mov ax,2000h ; ax=2000h cs:ip指向 0ff0:0103
mov ds,ax ;ds=2000h cs:ip = 0ff0:105
mov ax,;将ds:8即2000:8单元内容送入ax ax= c389h cs:ip=0ff0:8
mov ax, ; DS:2 即 2000:2入axax=ea66h 因为ax是16位 传送一个字 cs:ip=0ff0:10b
CS:IP指向指令DS: 指向数据只要不是指针指向的 你可以认为什么也不是
比较乱 不知道能不能看懂 - -
楼主是在叫大家帮你写作业么 你遇到了什么问题? 还是不知道答案?
麦麦Acassing 发表于 2013-12-28 20:28 static/image/common/back.gif
楼主是在叫大家帮你写作业么 你遇到了什么问题? 还是不知道答案?
我也有答案。就是搞不清楚第一题为什么DS的设置是1,而指向0000:0010;第二题执行完JMP 0FF0:0100后的指令为什么会到MOV BX,AX以及后面的指令。
就差一个问题了 ryan0632 发表于 2013-12-28 22:35 static/image/common/back.gif
这就是纯计算了,你好好看看寻址方式,物理地址=段地址*16+偏移地址,这个公式你压根就没搞懂
我以为只要有冒号就不用再乘十六了,现在我明白了 ryan0632 发表于 2013-12-29 08:36 static/image/common/back.gif
仔细看书,书上内容去掉代码示例写的并不多,不会的时候就算把这一章节内容背下来也没几分钟。
还有不 ...
好的,谢谢 jmp 0ff0:100 cs指针的位置就是1000:0嘛,后面的 mov ax,bx就没有执行执行的是1000:0的代码嘛 麦麦Acassing 发表于 2013-12-29 12:48 static/image/common/back.gif
jmp 0ff0:100 cs指针的位置就是1000:0嘛,后面的 mov ax,bx就没有执行执行的是1000:0的代码嘛
懂了:sweat: sokou001 发表于 2013-12-28 18:06
指令序列:mov ax,6622h ;ax=6622h 执行后cs:ip指向2000:3执行前cs:ip指向2000:0
jmp...
写得好详细 很好 但好像倒数第七行的cs:ip应该是0ff0,108 我疯狂我成功 发表于 2014-1-4 23:02 static/image/common/back.gif
您好,我是新鱼友阳阳,诚邀高手您进入QQ群339351993(仁阳编程交流):给予帮助。我和我的小伙伴都是刚涉及 ...
我又不是高手 天将 发表于 2014-1-5 09:16 static/image/common/back.gif
我又不是高手
呵呵,大家互相帮助而已 天将 发表于 2014-1-5 09:16 static/image/common/back.gif
我又不是高手
诚邀加入 嘻嘻 sokou001 发表于 2013-12-28 18:06 static/image/common/back.gif
指令序列:mov ax,6622h ;ax=6622h 执行后cs:ip指向2000:3执行前cs:ip指向2000:0
jmp...
是不是DS只读取该内存单位的数据,并不改变物理地址CS:IP? C:\Documents and Settings\Administrator\桌面 图片 javascript:;javascript:; 天将 发表于 2013-12-28 21:49
我也有答案。就是搞不清楚第一题为什么DS的设置是1,而指向0000:0010;第二题执行完JMP 0FF0:0100后的指 ...
就是啊,请问为什么指向是0000:0010呢?
天将 发表于 2013-12-28 21:49
我也有答案。就是搞不清楚第一题为什么DS的设置是1,而指向0000:0010;第二题执行完JMP 0FF0:0100后的指 ...
我懂了,不用了^_^
00010 ds:
+ 0000
---------
00010
所以地址就是0000:0010 0ff0H是那个值?我纠结与装个 麦麦Acassing 发表于 2013-12-28 20:28
楼主是在叫大家帮你写作业么 你遇到了什么问题? 还是不知道答案?
请问一下,个jmp 0ff0:0100是怎么算出它跳转的地址的,我用那个段地址x16+偏移地址算出来的不是10000H,可以帮忙解答一下么?
页:
[1]
2