王爽汇编语言学习笔记(九) --转移指令的原理



可以修改IP,或者同时修改CSIP的指令统称为转移指令。

段内转移:只修改IP 段间转移:同时修改CSIP

3 offset 取得标号的偏移地址

4 jmp为无条件转移指令,可以只修改IP,也可以同时修改CSIP

 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 指明了指令用标号的短地址和偏移地址修改CSIP

c) 转移地址在寄存器中的指令

  Jmp 16位 reg

d) 转移地址在内存中的jmp指令 

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

功能:从内存单元地址处开始存放着一个字,内存单元地址可用寻址方式的任一格式给出。

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

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

CS = 内存单元地址+2

IP = 内存单元地址

5 jcxz

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

Jcxz 标号 如果cx = 0,则转移到标号处执行;

位位移 标号处的地址 - jcxz指令后的第一个字节的地址;

8位位移的范围-128~127,用补码表示;

6 loop指令

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

指令格式:loop 标号

1)cx = cx-1; 2) 如果cx != 0 ip = ip + 8位位移;

根据位移进行转移的意义

jmp short 标号    jmp near ptr 标号 loop 标号  jcxz 标号

他们对IP的修改是根据转移目的地址和转移起始地址之间的位移来进行的。在他们对应的机器码中不包含转移的目的地址,而包含的是到目的地址的位移。这种设计方便了程序段在内存中的浮动装配。

 

  

 

你可能感兴趣的:(汇编语言)