xxasy 发表于 2011-6-27 23:25:20

汇编指令长度计算方法(找了很久只发现了这一个)

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

一、没有操作数的指令,指令长度为1字节。如
es:
ds:
cbw
xlat
等。

二、操作数只涉及寄存器的指令,指令长度为2字节。如
mov al,
mov ax,
mov ds,ax
等。

三、操作数涉及内存地址的指令,指令长度为3字节。如
mov al,
mov ax,
lea di,
mov ,ax
等。

四、操作数涉及立即数的指令,指令长度为:寄存器类型+2。
8位寄存器,寄存器类型=1;16位寄存器,寄存器类型=2。如
mov al,8 ;指令长度为2
mov ax,8 ;指令长度为3
等。

五、跳转指令,分3种情况,指令长度分别为2、3、5字节。
1、段内跳转,指令长度=(目标地址-指令当前地址)+1
jmp指令本身占用1个字节。
(目标地址-指令当前地址)若能用1个字节表示,则占用1个字节,整体指令长度为2字节;如
0113 jmp 0185 ;0185h-0113h=72h,72h可用1个字节表示
若需2个字节表示,则占用2个字节,整体指令为3个字节。如
0113 jmp 0845 ;0845h-0113h=732h,732h需用2个字节表示
2、段间跳转,指令长度为5字节。如
jmp 1234:5678

king嗜血法师 发表于 2011-6-28 07:11:12

谢谢分享{:5_109:}

sadinyu 发表于 2011-6-28 23:17:07

学习一下,谢谢了。{:7_174:}

幕府幽魂 发表于 2011-6-29 09:01:37

学习了谢谢{:1_1:}

Y.H 发表于 2011-6-29 09:55:41

真是辛苦你了感谢贡献谢谢……

张国祥 发表于 2011-6-30 14:51:21

顶楼主!这个很实用!

Cocol 发表于 2013-7-1 22:31:52

看看老帖,学习学习
页: [1]
查看完整版本: 汇编指令长度计算方法(找了很久只发现了这一个)