汇编语言学习之转移指令

操作符offset

  • 操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的偏移地址。

jmp指令

  • jmp为无条件转移指令,可以只修改IP,也可以同时修改CS和IP。

jmp指令要给出两种信息:
1、转移的目的地址
2、转移的距离(段间转移、段内短转移、段内近转移)

  • jmp short 标号(转到标号处执行指令)–段内短转移方式

jmp far ptr 标号–实现的是段间转移:
1、(CS)=标号所在段的段地址;(IP)=标号所在段中的偏移地址
2、far ptr 指明了指令用标号的段地址和偏移地址修改CS和IP


jmp 16位 reg

  • (IP) = (16位reg)

jmp word ptr 内存单元地址(段内转移)

  • 从内存单元地址处开始存放着一个字,是转移的目的偏移地址

imp dword ptr 内存单元地址(段间转移)

  • 从内存单元地址处开始存放这两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址。

jcxz指令

jcxz 标号(如果(CX)=0,转移到标号处执行):
1、当(CX)=0时,(IP)=(IP)+8位位移;
2、8位位移=标号处的地址-jcxz指令后的第一个字节的地址;
3、8位位移的范围位-128~127,用补码表示;
4、8位位移由编译器程序在编译时算出。
5、当(CX)!=0时,什么也不作(程序向下执行)


loop指令

  • loop指令为循环指令,所有的循环指令都是短转移 ,在对应的机器码中包含转移的位移,而不是目的地址。

loop 标号((CX)=(CX)-1,如果(CX)!=0,转移到标号处执行):
1、(CX)=(CX)-1
2、如果(CX)!=0,(IP)=(IP)+8位位移

ret和retf

  • ret指令用栈中的数据,修改IP的内容,从而实现近转移;
  • retf指令用栈中的数据,修改CS和IP的内容,从而实现远转移。

执行ret指令时,进行下面操作:
1、(IP)=((SS)*16+(SP))
2、(SP)=(SP)+2


执行retf指令时,进行下面4步操作:
1、(IP)=((SS)*16+(SP))
2、(SP)=(SP)+2
3、(IP)=((SS)*16+(SP))
4、(SP)=(SP)+2

call指令

  • 1、将当前的IP或CS和IP压入栈中;
  • 2、转移。

call 标号(将当前的IP压栈后,转到标号处执行指令)
CPU执行此种格式的call指令时,进行如下的操作:
1、(SP)=(SP)-2
2、((SS)*16+(SP))=(IP)
3、(IP)=(IP)+16位位移

  • 16位位移=标号处的地址-call指令后的第一个字节的地址;

call far ptr 标号(实现的是段间转移)

CPU执行此种格式的call指令时,进行如下的操作:
1、(SP)=(SP)-2
2、((SS)*16+(SP))=(CS)
3、(SP)=(SP)-2
4、((SS)*16+(SP))=(IP)
5、(CS)=标号所在段的段地址
6、(IP)=标号所在段中的偏移地址

call word ptr 内存单元地址

相当于进行下面指令:
1、push IP
2、jmp word ptr 内存单元地址


mul指令

  • mul是乘法指令:
  • 1、两个相乘的数,要么都是8位ie,要么都是16位。如果是8位,一个默认放在AL中,另一个放在8位reg或内存单元字节中;如果是16位,一个默认放在AX中,另一个放在16位reg或内存单元中。
  • 2、结果:如果是8位乘法,结果默认放在AX中;如果是16位乘法,结果高位默认在DX中存放,地位在AX中放。
  • 3、格式:mul reg 或 mul 内存单元
  • 4、例如:mul byte ptr ds:[0]-- (ax)=(al)*((ds)*16+0)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值