<学习笔记>王爽汇编语言__转移指令原理

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

8086CPU的转移行为有以下几类:

* 只修改IP时,称为段内转移,比如:jmp ax

* 同时修改CS和IP时,称为段间转移,比如:jmp 1000:0

由于转移指令对IP的修改范围不同,段内转移又分为:短转移和近转移

* 短转移IP的修改范围为:-128~127

* 近转移IP的修改范围为:-32768~32767

 

8086CPU的转移指令分为以下几类

* 无条件转移

* 条件转移

* 循环指令

* 过程

* 中断

 

 

1.操作符:offset

操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的便宜地址,例如:

assume cs:codesg
codesg segment

    start: mov ax,offset start
        s: mov ax,offset s

codesg ends
end start 

 

2.jmp指令

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


 3.依据位移进行转移的jmp指令

jmp short标号(转到标号处执行指令)

这种格式的jmp指令实现的是段内短转移,他对IP的修改范围为:-128~127。

比如以下程序:

assume cs:codesg

codesg segment

start: mov ax , 0
       jmp  short s
       add ax , 1

codesg ends
end start

上面程序执行后,ax中的值为1,跳过了add ax , 1这条指令。

jmp short s这条指令被Debug翻译成:jmp 0008,这个0008并不是目的地址,而是转移的地址长度。


4.转移目的的地址在指令中的jmp指令

jmp far ptr 实现的是段间的转移,又称为远转移,例如程序:

assume cs:codesg

codesg segment

    start: mov ax , 0
           mov bx , 0
           jmp far ptr s
           db 256 dup (0)
        s: add ax , 1
           inc ax

codesg ends
end start
这段代码中的 jmp far ptr s 被Debug翻译成 :jmp 0BBD:0000


5.转移地址在寄存器中的jmp指令

指令格式:jmp 16位reg


6.转移地址在内存中的jmp指令

功能:从内存单元地址出开始存放着第一个字,是转移的目的的偏移地址。

有两种格式:

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

比如如下指令:

mov ax , 0123H
mov ds:[0] , ax
jmp word ptr ds:[0]
执行后:(IP)=0123H

(2)jmp dword ptr

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

比如下面指令:

mov ax , 0123H
mov ds:[0] , ax
mov word ptr ds:[2] , 0
jmp dword ptr ds:[0]

执行后CS = 0 ,IP = 0123H


7.jcxz指令

jcxz指令为条件转移指令,所有的条件转移指令都是短转移。

指令格式:jcxz标号(如果(cx) = 0,转移到标号处执行)


8.loop指令

loop指令为循环指令,所有的循环指令都是短转移。

指令格式:loop 标号((cx) = (cx) - 1,如果(cx) != 0 , 转移到标号处执行)

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