随着学习的深入,我们会逐渐接触到计算机内部的构造方式,以及设计原理,这其中,计算机的寻址方式是一个很重要的概念,我们需要好好理解一下。
一.预备知识:
(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.基址+变址寻址
说的比较浅,主体的内容大致就这些了,有些地方只是一带而过,没有详细介绍,感兴趣的同学可以自己动手,上网去查资料看看。
原文地址:http://blog.csdn.net/u010084308/article/details/39677569