您的位置:首页 > 其它

Intel 80x86 寻址方式

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

一.预备知识:

(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.基址+变址寻址

说的比较浅,主体的内容大致就这些了,有些地方只是一带而过,没有详细介绍,感兴趣的同学可以自己动手,上网去查资料看看。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: