汇编语言-寻址方式

时间:2022-10-17 01:18:45

转载自: http://www.feiesoft.com/asm/03-8.html

一 定义

  在指令中,指定操作数或操作数存放位置的方法称为寻址方式

二 分类(16位cpu)

  1 立即数寻址

  2 寄存器寻址

  3 存储器寻址

    (1) 直接寻址

      操作数存放在内存中,在指令中直接给出该操作数的有效地址

      例: mov ax, [100]

    (2) 寄存器间接寻址

      操作数在存储器中,操作数的有效地址用SI、DI、BX和BP等四个寄存器之一来指定

      汇编语言-寻址方式

    (3) 寄存器相对寻址

      操作数在存储器中,其有效地址是一个基址寄存器(BX、BP)或变址寄存器(SI、DI)的内容和指令中的8位/16位偏移量之和。

      若有效地址用SI、DI和BX等之一来指定,则其缺省的段寄存器为DS;

      若有效地址用BP来指定,则其缺省的段寄存器为SS。

汇编语言-寻址方式

    (4)  基址变址寻址

      操作数在存储器中,其有效地址是一个基址寄存器(BX、BP)和一个变址寄存器(SI、DI)的内容之和。

汇编语言-寻址方式

    (5) 相对基址变址寻址

      操作数在存储器中,其有效地址是一个基址寄存器(BX、BP)的值、一个变址寄存器(SI、DI)的值和指令中的8位/16位偏移量之和。

汇编语言-寻址方式

三 32位cpu寻址方式

在32位微机系统中,除了支持前面的七种寻址方式外,又提供了一种更灵活、方便,但也更复杂的内存寻址方式,从而使内存地址的寻址范围得到了进一步扩大。

在用16位寄存器来访问存储单元时,只能使用基地址寄存器(BX和BP)和变址寄存器(SI和DI)来作为地址偏移量的一部分,但在用32位寄存器寻址时,不存在上述限制,所有32位寄存器(EAX、EBX、ECX、EDX、ESI、EDI、EBP和ESP)都可以是地址偏移量的一个组成部分。

当用32位地址偏移量进行寻址时,内存地址的偏移量可分为三部分:一个32位基址寄存器,一个可乘1、2、4或8的32位变址寄存器,一个8位/32位的偏移常量,并且这三部分还可进行任意组合,省去其中之一或之二。

32位基址寄存器是:EAX、EBX、ECX、EDX、ESI、EDI、EBP和ESP;
32位变址寄存器是:EAX、EBX、ECX、EDX、ESI、EDI和EBP(除ESP之外)。

汇编语言-寻址方式

用32位地址偏移量进行寻址的有效地址计算公式归纳如上所示。

由于32位寻址方式能使用所有的通用寄存器,所以,和该有效地址相组合的段寄存器也就有新的规定。具体规定如下:

1、地址中寄存器的书写顺序决定该寄存器是基址寄存器,还是变址寄存器;

如:[EBX+EBP]中的EBX是基址寄存器,EBP是变址寄存器,而[EBP+EBX]中的EBP是基址寄存器,EBX是变址寄存器;

2、默认段寄存器的选用取决于基址寄存器;

3、基址寄存器是EBP或ESP时,默认的段寄存器是SS,否则,默认的段寄存器是DS;

4、在指令中,如果使用段前缀的方式,那么,显式段寄存器优先。

下面列举几个32位地址寻址指令及其内存操作数的段寄存器。

指令的举例 访问内存单元所用的段寄存器
MOV  AX, [123456H] ;默认段寄存器DS
MOV  EAX, [EBX+EBP] ;默认段寄存器DS
MOV  EBX, [EBP+EBX] ;默认段寄存器SS
MOV  EBX, [EAX+100H] ;默认段寄存器DS
MOV  EDX, ES:[EAX*4+200H] ;显式段寄存器ES
MOV  [ESP+EDX*2], AX  ;默认段寄存器SS
MOV  EBX, GS:[EAX+EDX*2+300H] ;显式段寄存器GS
MOV  AX, [ESP]  ;默认段寄存器SS