实验:
1)使用debug,将下面的程序段写入内存,逐条执行,根据指令执行后的实际情况来填空。
① 在使用 a 命令输入指令调试前,使用 e 命令将内存单元 0021:0 ~0021:7 连续 8 个字节数据修改为 30H, 31H, 32H, 33H,34H,35H,36H,37H ② 将 P74 实验任务(1)中第 1行的 mov ax, ffff → 改为 mov ax, 0021
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:00FE 内容为:6462
push bx ;sp= 00FC 修改的内存单元地址是: 2200:00FC 内容为:6C6A
pop ax ;sp= 00FE ;ax=6C6A
pop bx ;sp= 0100 ;bx=6462
push [4] ;sp= 00FE 修改的内存单元地址是: 2200:00FE 内容为:3534
push [6] ;sp= 00FC 修改的内存单元地址是:2200:00FC 内容为:3736
下面是相关的实验的过程截图:
从上面的这些过程以及步骤中 我们可以将这些自己的推测以及实验的结果进行验证。
2) 仔细的观察下面的图的实验过程,然后分析:为什么2000:0至2000:f中的内容会发生改变?
我们发现原来寄存器里cs和IP里的值都被赋值给地址了,这个貌似是书上所说的叫中断机制。所以我就查了一下:
中断就是一种特殊的信号,CPU一旦检查到了这种信号,他就会停止当前的指令,转而去处理这个特殊的信号,中断信号分为两种,一种是内中断,也叫程序中断,另一种是外中断,也叫硬件中断,硬件中断一般是某某某硬件准备好了,向CPU请求中断,而程序中断一般是出现了一些错误,如除数为0,或者人工进行中断,如Debug。
貌似是在中断若想在计算机中使用自定义的中断函数,只需要将中断函数的地址注册到中断向量表中就可以了,即将中断向量表中空闲的位置写入自定义中断函数的CS与IP。
这种情况好像正是我们这里的情况 所以猜测了一下 应该是这个原因。
实验结论:
1)这次可以非常有趣的了解到很多不同的指令。
2)可以更好的了解到栈的使用。
3)查找到并且了解了有关中断机制的相关事情。
原文地址:https://www.cnblogs.com/QiaoGeGe/p/9867739.html