汇编语言(第三版,王爽)读书笔记
转移指令的原理
可以修改ip或cs和ip的指令统称为转移指令。
操作符offset
操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的偏移地址。
例如mov ax,offset start
就是将start的偏移地址赋给ax
jmp指令
jmp为无条件转移指令,可以修改cs和ip或ip。
jmp指令给出两种信息:
- 转移的目的地址
- 转移的距离(段间转移、段内短转移、段内近转移)
依据位移进行转移的jmp指令
jmp short 标号(转到标号处执行指令)
这种格式实现的是段内短转移,它对IP的修改范围为-128-127。jmp指令中的short,说明指令进行短转移。“标号”是代码段中的标号,指明了指令要转移的目的地,让cs:ip指向它。
例如:
start:mov ax,0
jmp short s
add ax,1
s:inc ax
“jmp short 标号”指令所对应的机器码中,并不包含目的地址,而是包含转移的位移,这个位移是汇编编译器根据“标号”计算出来的
转移的目的地址在指令中的jmp指令
jmp far ptr 标号
实现的是段间转移(远转移),指明了指令用标号的段地址和偏移地址修改cs和ip。
转移地址在寄存器中的jmp指令
jmp 16位reg
功能:(IP)=(16位reg)
转移地址在内存中的jmp指令
转移地址在内存中的jmp指令有两种格式:
-
jmp word ptr 内存单元地址
(段内转移)
功能:从内存单元地址处开始存放着一个字,是转移的目的偏移地址
例如jmp word ptr [bx]
或jmp word ptr ds:[0]
-
jmp dword ptr 内存单元地址
(段间转移)
功能:从内存单元开始处存放着两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址。
(cs)=(内存单元地址+2),(ip)=(内存单元地址)
jcxz指令
jcxz指令为有条件转移指令,所有的有条件转移指令都是短转移,在对应的机器码中包含转移的位移,而不是目标地址。
jcxz 标号
的功能相当于if((cx)==0) jmp short 标号
loop指令
loop指令为循环指令,所有的循环指令都是短转移。
指令格式:loop 标号
功能:(cx)--
,if((cx)≠0) jmp short 标号
学完一半啦,加油!