qq498313523 发表于 2015-11-29 19:19:27

支持!!!

985840427 发表于 2015-12-7 15:02:19

学习了

帅的一B 发表于 2016-2-25 16:02:34

(1) 在Debug中,用“d 0:0 1f”查看内存,结果如下。
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=0000H
mov al, AX=00E6H
mov bx,0 BX=0000H
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和相关寄存器中的数值。
③ 再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?

解: 初始值:CS=2000H,IP=0,DS=1000H,AX=0,BX=0
① ②
mov ax,6622H AX=6622H 其他寄存器保持不变,以下同理
jmp 0ff0:0100 CS=0ff0H,IP=0100H
mov ax,2000H AX=2000H
mov ds,ax DS=20000H
mov ax, AX=C389H
mov ax, AX=EA66H

③ 没有区别,被CS:IP指向的信息是程序;被传送、运算等指令操作的是数据

吃货YA鸭 发表于 2017-6-9 11:30:24

qufanming 发表于 2015-9-19 16:25
IP 0100
:0
-r ds


你跳转到ff0:100位置,意味着这个位置你也要有同样的数据和同样的指令,你没发现你跳转过去之后执行的指令发生变化了么?

吃货YA鸭 发表于 2017-6-9 11:32:34

白开水1982 发表于 2015-9-21 19:07
我还是不明白小甲鱼 能讲讲吗

人家楼上已经剖析的很清楚了,不知道还怎么详细的解释额,只能劝你好好看看基础知识,一点点看,不要贪多冒进就好

siugaawai 发表于 2017-11-5 19:51:33

380683310 发表于 2014-9-24 17:17
前面mov ax,1 mov ds,ax,这两句已经把DS的段地址设置为0001,运行mov ax,时的物理地址应该为00010, ...

那既然是这样,为什么不是读取0001:0000,而是0000:0010?
题目不是mov ax,吗?

just_it 发表于 2018-2-5 02:18:46

qkqpihumq 发表于 2014-9-17 10:28
检测点3.1
(1)在DEBUG中,用 "D 0:0 lf" 查看内存,结果如下:
0000:0000 70 80 F0 30 EF 60 30 E2-00 80 ...

为什么 mov ax, ,传输给ax的是2662,为什么跳过了0000:0000到了0000:0010?
另外 -d 0000:0 lf中的lf是什么意思?感谢!

just_it 发表于 2018-2-5 02:23:08

just_it 发表于 2018-2-5 02:18
为什么 mov ax, ,传输给ax的是2662,为什么跳过了0000:0000到了0000:0010?
另外 -d 0000:0 lf   ...

第一个问题明白了,因为前面有 mov ax,1 然后mov ds,ax

489917498 发表于 前天 20:25

15801861509 发表于 2014-9-10 20:13
mov ax,   那么答案是0870H才对啊。为什么是2662H呢。

因为ds=1,偏移等于零的话。就是指向10这个单元又因为是字型,所以要引用高地址的数据。在每一单元中从左往右所以是2662
页: 1 [2]
查看完整版本: 求汇编检测点3.1答案与解析