- 1.ret:用栈中的数据,修改IP的内容,从而实现近转移.
- 2.retf:用栈中的数据,修改CS和IP的内容,从而实现远转移.
3.可以修改IP,或同时修改CS和IP的指令统称为转移指令
4.只修改IP时,称为段内转移;同时修改CS和IP时.称为段间转移
5.由于转移指令对IP修改范围不同,段内转移又分为:①短转移 ②.近转移
6.8086CPU的转移指令分为: ①.无条件转移指令
②.条件转移指令
③.循环指令
④.过程
- ⑤.中断
- 7.offset:取得标号的偏移地址
8.jmp为无条件转移指令,可以修改IP,也可以同时修改CS和IP,jmp指令要给出两个信息:
①.转移的目的地址
②.转移的距离
9.jmp short 标号(转到标号处执行指令) :段内短转移,它对IP的修改范围为-128~127,转移指令结束后,CS:IP应该向指向标号处的指令
10.CPU在执行jmp指令的时候并不需要转移的目的地址,CPU不需要目的地址就可以对IP的修改.
11."jmp short 标号"的功能为:(IP)=(IP)+8;执行过程:
①.8位位移=标号处的地址-jmp指令后的第一个字节的地址
- ②.short表明此处的位移是8位移
- ③.8位位移的范围是-128~127
- ④.8位位移由编译程序在编译时算出
12."jmp near ptr 标号":表示的段内近转移
13."jmp far ptr 标号":表示的是段间转移,又称为远转移,段内转移称为近转移
14."jmp word ptr 内存单元地址":段内转移,功能:从内存单元地址处开始存放着一个字,是转移目的偏移地址
15."jmp dword ptr 内存单元地址":段间转移,从内存单元地址处开始存放着两个字,高地址处的字是转移的目的段地址,地址处是转移的目的偏移地址
16.jcxz : 为有条件转移指令,所有的有条件转移指令都是短转移,在对应的机器码中包含转移的位移,而不是目的地址,对IP的修改范围是-128~127
if((cx)==0) jmp short 标号
- 17.loop指令为循环指令,所有的循环指令都是短转移,在对应的机器码中包含转移的位移,而不是目的地址,对IP的修改范围为:-128~127,具体操作: ①.(cx)=(cx)-1
- ②.如果(cx)!=0,(IP)=(IP)+8位位移
loop的标号即为:(CX)-- if ((cx)!=0) jmp short 标号
18. jmp short 标号 / jmp near ptr 标号 / jcxz 标号 /loop 标号等几种汇编指令,它们对IP的修改是根据转移目的地址和转移起始地址之间的位移来进行的,在它们对应的机器码中不包含转移的目的地址,而包含的是到目的地址的位移.