汇编语言学习笔记 - 第九章

第 9 章

汇编语言学习笔记 - 第九章

9.1 操作符 offset

汇编语言学习笔记 - 第九章
汇编语言学习笔记 - 第九章

举例:
汇编语言学习笔记 - 第九章

9.2 jmp 指令

  • jmp为无条件转移指令,可以只修改IP,也可以同时修改CS和IP。
  • jmp指令要给出两种信息:
    (1) 转移的目的地址
    (2) 转移的距离(段间转移、段内短转移,段内近转移)

9.3 依据位移进行转移的 jmp 指令

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

这种格式的 jmp 指令实现的是段内短转移,它对IP的修改范围为-128-127,也就是说,它向前转移时可以最多越过128个字节,向后转移可以最多越过127个字节。jmp 指令中的“short”符号,说明指令进行的是短转移。jmp 指令中的“标号”是代码段中的标号,指明了指令要转移的目的地,转移指令结束后,CS:IP应该指向标号处的指令。

举例:
汇编语言学习笔记 - 第九章

  • CPU 在执行 jmp 指令的时候并不需要转移的目的地址。

汇编语言学习笔记 - 第九章
汇编语言学习笔记 - 第九章

9.4 转移的目的地址在指令中的 jmp 指令

  • 前面讲的jmp指令,其对应的机器指令中并没有转移的目的地址,而是相对于当前 IP的转移位移。
  • “jmp far ptr 标号"实现的是段间转移,又称为远转移。
  • (CS = 标号所在段的段地址;(IP)= 标号在段中的偏移地址。
    far ptr 指明了指令用标号的段地址和偏移地址修改CS和IP。

汇编语言学习笔记 - 第九章

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

  • 指令格式:jmp 16位reg
    功能:(IP) = (16 位 reg)

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

汇编语言学习笔记 - 第九章
汇编语言学习笔记 - 第九章

9.7 jcxz 指令

汇编语言学习笔记 - 第九章

9.8 loop 指令

汇编语言学习笔记 - 第九章

9.9 根据位移进行转移的意义

汇编语言学习笔记 - 第九章

举例:
汇编语言学习笔记 - 第九章

9.10 编译器对转移位移超界的检测

  • 注意,根据位移进行转移的指令,它们的转移范围受到转移位移的限制,如果在源程序中出现了转移范围超界的问题,在编译的时候,编译器将报错。

举例:
汇编语言学习笔记 - 第九章
汇编语言学习笔记 - 第九章