天将 发表于 2013-12-28 18:06:38

检测点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和相关寄存器的数值。

③   再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?


sokou001 发表于 2013-12-28 18:06:39


指令序列: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:03

楼主是在叫大家帮你写作业么 你遇到了什么问题? 还是不知道答案?

天将 发表于 2013-12-28 21:49:24

麦麦Acassing 发表于 2013-12-28 20:28 static/image/common/back.gif
楼主是在叫大家帮你写作业么 你遇到了什么问题? 还是不知道答案?

我也有答案。就是搞不清楚第一题为什么DS的设置是1,而指向0000:0010;第二题执行完JMP 0FF0:0100后的指令为什么会到MOV BX,AX以及后面的指令。

天将 发表于 2013-12-28 22:24:00

就差一个问题了

天将 发表于 2013-12-29 08:21:31

ryan0632 发表于 2013-12-28 22:35 static/image/common/back.gif
这就是纯计算了,你好好看看寻址方式,物理地址=段地址*16+偏移地址,这个公式你压根就没搞懂

我以为只要有冒号就不用再乘十六了,现在我明白了

天将 发表于 2013-12-29 09:12:10

ryan0632 发表于 2013-12-29 08:36 static/image/common/back.gif
仔细看书,书上内容去掉代码示例写的并不多,不会的时候就算把这一章节内容背下来也没几分钟。

还有不 ...

好的,谢谢

麦麦Acassing 发表于 2013-12-29 12:48:20

jmp 0ff0:100 cs指针的位置就是1000:0嘛,后面的 mov ax,bx就没有执行执行的是1000:0的代码嘛

天将 发表于 2013-12-29 16:44:25

麦麦Acassing 发表于 2013-12-29 12:48 static/image/common/back.gif
jmp 0ff0:100 cs指针的位置就是1000:0嘛,后面的 mov ax,bx就没有执行执行的是1000:0的代码嘛

懂了:sweat:

15岁的小朋友 发表于 2013-12-30 09:35:41

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-5 09:16:27

我疯狂我成功 发表于 2014-1-4 23:02 static/image/common/back.gif
您好,我是新鱼友阳阳,诚邀高手您进入QQ群339351993(仁阳编程交流):给予帮助。我和我的小伙伴都是刚涉及 ...

我又不是高手

我疯狂我成功 发表于 2014-1-5 11:29:43

天将 发表于 2014-1-5 09:16 static/image/common/back.gif
我又不是高手

呵呵,大家互相帮助而已

我疯狂我成功 发表于 2014-1-5 11:30:14

天将 发表于 2014-1-5 09:16 static/image/common/back.gif
我又不是高手

诚邀加入 嘻嘻

goemlitao 发表于 2014-1-7 13:45:19

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?

tyutzt 发表于 2014-1-22 11:14:32

C:\Documents and Settings\Administrator\桌面

tyutzt 发表于 2014-1-22 11:16:14

图片 javascript:;javascript:;

奇小才 发表于 2017-2-2 16:22:51

天将 发表于 2013-12-28 21:49
我也有答案。就是搞不清楚第一题为什么DS的设置是1,而指向0000:0010;第二题执行完JMP 0FF0:0100后的指 ...

就是啊,请问为什么指向是0000:0010呢?

奇小才 发表于 2017-2-2 16:26:13

天将 发表于 2013-12-28 21:49
我也有答案。就是搞不清楚第一题为什么DS的设置是1,而指向0000:0010;第二题执行完JMP 0FF0:0100后的指 ...

我懂了,不用了^_^
00010   ds:
+ 0000   
---------
00010
所以地址就是0000:0010

HUANGGUOHUA 发表于 2017-2-4 11:38:45

0ff0H是那个值?我纠结与装个

HUANGGUOHUA 发表于 2017-2-4 11:58:21

麦麦Acassing 发表于 2013-12-28 20:28
楼主是在叫大家帮你写作业么 你遇到了什么问题? 还是不知道答案?

请问一下,个jmp 0ff0:0100是怎么算出它跳转的地址的,我用那个段地址x16+偏移地址算出来的不是10000H,可以帮忙解答一下么?
页: [1] 2
查看完整版本: 检测点3.1求助