qvq123 发表于 2019-12-3 20:44:37

检测点3.1

(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)内存中的情况如图所示
各寄存器的初始值:CS=2000H,IP=0,DS=1000H,AX=0,BX=0;
a.        写出CPU执行的指令序列(用汇编指令写出)
b.        写出CPU执行每条指令后,CS、IP和相关寄存器中的数值
c.        再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序
        MOV                AX,6622H
JMP                        0FF0:0100
MOV                AX,2000H
MOV                DS,AX
MOV                AX,
MOV                AX,
        第一条:CS: 2000H 、IP: 0003H 、DS: 1000H 、AX: 6622H 、BX: 0000H
第二条:CS: 0FF0H 、IP: 0100H 、DS: 1000H 、AX: 6622H 、BX: 0000H
第三条:CS: 0FF0H 、IP: 0103H 、DS: 1000H 、AX: 2000H 、BX: 0000H
第四条:CS: 0FF0H 、IP: 0105H 、DS: 2000H 、AX: 2000H 、BX: 0000H
第五条:CS: 0FF0H 、IP: 0108H 、DS: 2000H 、AX: C389H 、BX: 0000H
第六条:CS: 0FF0H 、IP: 010BH 、DS: 2000H 、AX: EA66H 、BX: 0000H
        CS(CodeString)指向的是指令段地址,是指令段寄存器。
DS(DataString)指向的是数据段地址,数据段寄存器。
SS(StackString)指向的是栈顶段地址,栈段寄存器。
内存中的数据和程序没有区别,说都是以2进制形式存储,CS指向的段地址里,存的是指令,DS指向的段地址里,存的是数据。
数据和程序在内存中都是以2进制的数据存贮,只有当2进制的数据被CS:IP指向时,才成为可执行的指令或程序。
数据和程序在内存中是没有区别的,它们都是内存中的数据,当EIP指针指向哪CPU就加载那段内存中的数据,如果是不正确的指令格式,CPU就会发生错误中断。
在现在CPU的保护模式中,每个内存段都有其描述符,这个描述符记录着这个内存段的访问权限(可读,可写,可执行),这就变相的指定了哪些内存中存储的是指令那些是数据。
页: [1]
查看完整版本: 检测点3.1