1 可以修改IP,或者同时修改CS和IP的指令统称为转移指令。
2 段内转移:只修改IP 段间转移:同时修改CS和IP
3 offset 取得标号的偏移地址
4 jmp为无条件转移指令,可以只修改IP,也可以同时修改CS和IP
a)依据位移进行转移的jmp指令
Jmp short 标号 段内短转移
由图中可发现,JMP 0008的机器码为EB03,这个机器码中不包含转移的目的地址,
CPU在执行jmp指令的时候并不需要转移的目的地址,包含的是转移的位置,这个位移是编译器根据汇编指令中的“标号”计算出来的。
Jmp short 标号的功能: IP = IP+8
1) 8位位移 = 标号处的地址 - jmp指令后的第一个字节的地址;
2)short指明此处的位移为8位位移;
3)8位位移的范围-128~12,用补码表示;
4)8位位移由编译程序在编译时算出。
Jmp near ptr 标号
1) 16位位移 = 标号处的地址 - jmp指令后的第一个字节的地址;
2) near ptr 指明此处的位移为16位位移,进行段内近转移;
3) 16位位移的范围为-32768~32767,用补码表示;
4) 16位位移由编译程序在编译时算出。
b) 转移的目的地址在指令中的jmp指令
Jmp far ptr 标号 段间转移
1) CS=标号所在的段的短地址 IP = 标号所在段的偏移地址
Far ptr 指明了指令用标号的短地址和偏移地址修改CS和IP
c) 转移地址在寄存器中的指令
Jmp 16位 reg
d) 转移地址在内存中的jmp指令
Jmp word ptr 内存单元地址(段内转移)
功能:从内存单元地址处开始存放着一个字,内存单元地址可用寻址方式的任一格式给出。
Jmp dword ptr 内存单元地址(段间转移
功能:从内存单元地址处开始存放着两个字,高地址处的字是转移目的地址的段地址,低地址处是转移的目的地址的偏移地址。
CS = 内存单元地址+2
IP = 内存单元地址
5 jcxz
jcxz指令为有条件转移指令,所有的有条件转移指令都是短转移,在对应的机器码中包含转移的位移,而不是目的地址。
Jcxz 标号 如果cx = 0,则转移到标号处执行;
8 位位移 = 标号处的地址 - jcxz指令后的第一个字节的地址;
8位位移的范围-128~127,用补码表示;
6 loop指令
Loop指令为循环指令,所有的循环指令都是短转移,在对应的机器码中包含转移的位移,而不是目的地址。
指令格式:loop 标号
1)cx = cx-1; 2) 如果cx != 0 ip = ip + 8位位移;
7 根据位移进行转移的意义
jmp short 标号 jmp near ptr 标号 loop 标号 jcxz 标号
他们对IP的修改是根据转移目的地址和转移起始地址之间的位移来进行的。在他们对应的机器码中不包含转移的目的地址,而包含的是到目的地址的位移。这种设计方便了程序段在内存中的浮动装配。