实验二

一使用Debug,将下面的程序段写入内存,逐条执行,根据指令执行后的实际运行情况填空。

1. 先使用 e 命令将内存单元 0021:0 ~0021:7 连续 8 个字节数据修改为 30H, 31H, 32H, 33H,34H,35H,36H,37H 

2.第 1行的 mov ax, ffff 改为 mov ax, 0021 

下面开始做实验

先把所有指令用a指令写入

现在来逐条执行

通过观察执行后的结果很容易填写下面的空格

mov ax,0021

mov ds,ax

mov ax,2200

mov ss,ax

mov sp,0100

mov ax,[0]                                            ;ax= 3130          

add ax,[2]                                             ;ax= 6462            

mov bx,[4]                                            ;bx= 3534            

add bx,[6]                                             ;bx= 6C6A            

push ax                                                ;sp= 00FE           ;修改的内存单元的地址是 2200:FE到FF 内容为   62       64 

ax入栈 sp=sp-2=0100H-2  =00FEH             

push bx                                                ;sp= 00FC           ;修改的内存单元的地址是 2200:FC到FD 内容为   6A        6C     

bx入栈  sp=sp-2=00FEH-2=00FCH           

pop ax                                                  ;sp= 00FE           ;ax=  6C6A     

将栈顶元素6C6A弹出送入ax中,首先ax=6C6A,然后sp=sp+2=FCH+2=FEH         

pop bx                                                  ;sp=0100            ;bx=   6462       

同上    

push [4]                                                ;sp= 00FE          ;修改的内存单元的地址是  2200:FE到FF    内容为   34      35                

push [6]                                                ;sp= 00FC          ;修改的内存单元的地址是  2200:FC到FD   内容为    36      37        

二  仔细观察图3.19中的实验过程,然后分析:为什么2000:0~2000:f中的内容会发生改变?

书上的截图只查看了指令运行前和全部运行结束后2000:0~2000:f中的内容改变了

我们来一步一步的运行和查看 观察是哪一步导致了这样的改变

1.首先将指令全部写入

2.执行第一个指令

发现执行完后并没有改变其中的值

3我们再执行下一个

这一步直接执行了mov ss,ax  mov sp,10两个指令 其中 2000:0到f的值改变

说明是这两个指令导致了这个结果  

用t命令直接执行了两个指令书P73页讲到了这个现象,

但只是说明了这个现象叫中断机制没有解释。

到网上搜索一下这个中断机制:执行中断例程时,CPU会将一些中断例程使用的的寄存器变量自动压栈到栈中,此例中就包括了上述的寄存器变量的值。

这也就说明了这个现象的原因。

原文地址:https://www.cnblogs.com/WJL123/p/9858213.html