欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

jmp指令

程序员文章站 2022-05-03 15:54:05
...

功能:
无条件转移指令

jmp指令要给出两种信息:

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

段内短转移:

jmp short 标号)

assume cs:code
code segment
	start:mov ax,0
			jmp short s
			add ax,1
	s:		inc ax
code ends

end start

上面的程序执行后ax为1,add ax,1没有执行

CPU在执行jmp指令时候并不需要转移的地址,CPU的执行过程如下:

  • 从CS:IP执行的内存单元读取指令,读取的指令进入指令缓冲器

  • IP=IP+所读取的指令长度,从而指向下一条指令

  • 执行指令
    简单来说就是:读取---------修改IP----------执行
    jmp short 标号指令所对应的机器码中,并不包含转移的目的地址,而是包含转移的移位。这移位是编译器根据汇编指令中的标号计算出来的
    jmp指令
    jmp short 标号的功能实际上为:IP=IP+8位位移

  • 8位位移=标号处的地址-jmp指令后的第一个字节地址
    比如上图中执行jmp s0,标号s0的地址是0006,jmp指令后的第一个字节地址是0003,所以8位位移是3,IP=3+3=6,此时偏移地址为0006,CS没有变,根据CS:IP,CPU会找到要执行的代码是inc bx

jmp near ptr 标号
功能:IP=IP+16位地址

相关标签: win32汇编