汇编语言读书笔记(9.转移指令的原理)

汇编语言(第三版,王爽)读书笔记

转移指令的原理

可以修改ip或cs和ip的指令统称为转移指令。

操作符offset

操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的偏移地址。
例如mov ax,offset start就是将start的偏移地址赋给ax

jmp指令

jmp为无条件转移指令,可以修改cs和ip或ip。
jmp指令给出两种信息:

  1. 转移的目的地址
  2. 转移的距离(段间转移、段内短转移、段内近转移)

依据位移进行转移的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指令有两种格式:

  1. jmp word ptr 内存单元地址(段内转移)
    功能:从内存单元地址处开始存放着一个字,是转移的目的偏移地址
    例如jmp word ptr [bx]jmp word ptr ds:[0]

  2. jmp dword ptr 内存单元地址(段间转移)
    功能:从内存单元开始处存放着两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址。
    (cs)=(内存单元地址+2),(ip)=(内存单元地址)

jcxz指令

jcxz指令为有条件转移指令,所有的有条件转移指令都是短转移,在对应的机器码中包含转移的位移,而不是目标地址。
jcxz 标号的功能相当于if((cx)==0) jmp short 标号

loop指令

loop指令为循环指令,所有的循环指令都是短转移。
指令格式:loop 标号
功能:(cx)--if((cx)≠0) jmp short 标号

学完一半啦,加油!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值