检测点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]