实验3 转移指令跳转原理及其简单应用编程

实验任务1

 

问题①
① line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机
器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明
是如何计算得到跳转后标号s1其后指令的偏移地址的。
跳转的位移量:-14
 
loop指令为循环指令是短转移,在对应的机器码中包含转移的位移
cpu计算当前地址到标号地址的位移量,直接加在ip之后
loop指令执行之后IP变成001B,需要跳转到000D,所以偏移量为-14
 
问题②
② line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机
器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明
是如何计算得到跳转后标号s2其后指令的偏移地址的。
跳转的位移量:-16
loop指令执行之后,偏移地址为0039H,跳转的偏移地址是0029H,所以偏移量为-16
 
问题③
③ 附上上述分析时,在debug中进行调试观察的反汇编截图
 
 
实验任务2

 

根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,

寄存器(ax) = 0021h 寄存器(bx) = 0026h 寄存器(cx) = 076ch

 

offset分别将s1,s2处地址传入偏移量为ds:[0]和ds:[2],第一次call指令执行,将下一条指令

s1处地址入栈,并跳转至ds:[0]中地址即s1处,执行pop指令将栈中s1的地址传给ax,第二

次同理,不过入栈双字长度,即入栈下一条指令的段地址和偏移地址。ax中存放了s1处指令

在内存中的偏移地址,bx中存放了标号s2处指令在内存中的偏移地址,cx中存放了s2处指令

在内存中的段地址。

 

 

实验任务3

 

 

实验任务4

 

 

实验任务5

 

 

 

 

 

posted @ 2021-11-27 18:44  XU_qwe  阅读(88)  评论(0编辑  收藏  举报