汇编——第九章转移指令的原理
** 可以修改IP,或者同时修改CS 和IP 的指令统称为转移指令。**概括来讲,转移指令就是可以控制CPU执行内存种某处代码的指令。
9.1 操作符 offset
9.2 jmp 指令
jmp为无条件转移指令,可以只修改IP也可以同时修改CS和IP。
jmp指令要给出两种信息:
(1)转移的目的地址
(2)转移的距离(段间转移、段内短转移、段内近转移)
9.3 依据位移进行转移的jmp指令
jmp short 标号(转移到标号处执行指令)
这种实现的时段内短转移,它对IP的修改范围为-128 ~ 127,也就是说它向前最多转移128个字节,向后转移最多127个字节。jmp指令中的“short”符号说明指令是短转移。jmp指令中的“标号”是代码段中的标号,指明了指令要转移的目的地,转移指令结束后,CS:IP应该指向标号处的指令。
9.6 转移地址在内存中的jmp指令
转移地址在内存中的jmp指令有两种格式。
(1)jmp word ptr 内存单元地址(段内转移)
功能:从内存单元地址处开始存放着一个字,是转移的目的偏移地址。
(2)jmp dword ptr 内存单元地址(段间转移)
功能:从内存单元地址处开始存放着两个字,高地址处的字是转移的目的段地址,低地址处是目标的偏移地址。
(CS)=(内存单元地址+2)
(IP)=(内存单元地址)
9.7 jcxz指令
jcxz指令是一个有条件转移指令,所有的条件住哪一指令都是短转移。 IP的修改范围都为:-128 ~ 127。
指令格式:jcxz 标号(如果(CX) = 0,转移到标号处执行。)
其功能的解释相当于:if((CX) == 0) jmp short 标号。
9.8 loop 指令
loop 指令为循环指令,所有的循环指令都是短转移。IP修改的范围为:-128 ~ 127.
指令格式:loop 标号((CX) = (CX) - 1, 如果(CX) != 0,转移到标号处执行。)