一使用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会将一些中断例程使用的的寄存器变量自动压栈到栈中,此例中就包括了上述的寄存器变量的值。
这也就说明了这个现象的原因。