Intel 80x86 寻址方式

时间:2022-05-12 03:14:05

     随着学习的深入,我们会逐渐接触到计算机内部的构造方式,以及设计原理,这其中,计算机的寻址方式是一个很重要的概念,我们需要好好理解一下。

一.预备知识:

    (1)操作数

    在接触寻址方式之前,我们还要先了解一下操作数的概念,根据操作数存放方式的不同,我们可以将操作数分成3类,

    1.立即操作数:操作数包含在本条指令中;

    2.寄存器操作数:操作数存放在CPU的某个寄存器中;

    3.存储器(内存)操作数:操作数存放在存储器中;

    (2)逻辑地址

     逻辑地址 = 段地址(存储单元所在逻辑段地址)左移4位 + 偏移地址(该单元的偏移地址)

     我们可以发现,这是通过左移的方式将16位扩展成了20位,当初好像因为为了方便处理兼容问题,才采用这种扩展方式的。

     段 是内存设计模型的结果,在80x86内存模型中,各处理器的地址空间不一致(因为要保持兼容性),但它们都被分割成以64KB为单位的区域,每个这样的区域称为段。

     note:不同的段地址和偏移地址可能组成相同的内存地址,如:(段地址(左移4为后):A0000,偏移地址FFFF,最终地址AFFFF;  段地址(左移4位后):AFFF0,偏移          地址000F,最终地址AFFFF)。


二.寻址方式的分类:

    操作数类型的相同,也会导致寻址方式类型的差异。寻址方式可以分为三大类:

    (1)立即寻址:操作数是立即操作数;MOV AL,1234H

    (2)寄存器寻址:操作数是寄存器操作数;MOV DS,AX

    (3)存储器操作数的寻址又可以分为5种:

             1.直接寻址:偏移地址直接存放在存储器中;MOV BX,DS:[1234H]

             2.寄存器间接寻址:将操作数在存储器中的地址放到寄存器中,先从寄存器中取出操作数的地址,再从存储器对应的内存单元中取出操作数;MOV AL,[BX]

                                                一般的寄存器默认的是DS(数据段),BP寄存器默认的是SS(堆栈段);

             3.基址寻址:存储单元的偏移地址为规定的基址寄存器(BX, BP)的内容与一个常量得喝,MOV DL,DS:[BX+2]

             4.变址寻址:MOV DL,[DI+2]

             5.基址+变址寻址


说的比较浅,主体的内容大致就这些了,有些地方只是一带而过,没有详细介绍,感兴趣的同学可以自己动手,上网去查资料看看。