汇编指令长度的判断

Posted 2f28

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了汇编指令长度的判断相关的知识,希望对你有一定的参考价值。

技术分享图片

其中IP=IP+所读指令的字节数。

那么,所读指令的字节数应该怎么判断呢?

汇编指令长度与寻址方式有关,规律或原则如下:

一、没有操作数的指令,指令长度为1个字节

二、操作数只涉及寄存器的的指令,指令长度为2个字节

    如:mov bx,ax

三、操作数涉及内存地址的指令,指令长度为3个字节

    如:mov ax,ds:[bx+si+idata]

四、操作数涉及立即数的指令,指令长度为:寄存器类型+1

    8位寄存器,寄存器类型=1,如:mov al,8;指令长度为2个字节

    16位寄存器,寄存器类型=2,如:mov ax,8;指令长度为3个字节

五、跳转指令,分为2种情况:

1、段内跳转(指令长度为2个字节或3个字节)

jmp指令本身占1个字节

段内短转移,8位位移量占一个字节,加上jmp指令一个字节,整条指令占2个字节

如:jmp short opr

段内近转移,16位位移量占两个字节,加上jmp指令一个字节,整条指令占3个字节

如:jmp near ptr opr

2、段间跳转,指令长度为5个字节

如:jmp dword ptr table[bx][di]

  jmp far ptr opr

  jmp dword ptr opr 

注意:形如“jmp 1234:5678”的汇编指令,是在Debug中使用的汇编指令,汇编编译器并不认识,如果在源程序中使用,那么在编译时便会报错。

转自:https://blog.csdn.net/qq_36499686/article/details/78302165?locationNum=2&fps=1

以上是关于汇编指令长度的判断的主要内容,如果未能解决你的问题,请参考以下文章

汇编指令和机器码的转换?

汇编语言--指令

汇编基础 汇编指令

汇编_移位指令_CMOS RAM读取月份

关于汇编语言中的LOOP指令

麻烦大家给我介绍一下汇编指令mov的用法吧