指令一之操作数的寻址方式

一、引言

视图

在这里插入图片描述

指令

指令=操作码 操作数1 操作数2
cpu一条接着一条地执行指令

在这里插入图片描述

段寄存器

ES:附加段寄存器
CS:代码段寄存器
SS:堆栈寄存器
DS:数据段寄存器

在这里插入图片描述

区分有效地址和实际中内存中的地址:
实际中内存的地址=有效地址+段地址

EIP如何发生改变

方式一:自动增量
方式二:跳转指令:更改程序计数器(PC)
方式三:分支指令:根据程序状态字PSW寄存器(也被称作标志寄存器FR)有条件地更改程序计数器

二、操作数寻址方式(Operand-addressing Mode)

是什么决定了在指令执行的每个步骤中将获取哪个数据项呢?

在c语言中:使用变量
在机器编码中:使用操作数寻址

操作数寻址方式分类:

  1. 寄存器寻址
  2. 立即寻址
  3. 存储器寻址

1.寄存器寻址(Register Addressing)

所有的操作数都存储在通用寄存器中

  • 16位:AX,BX,CX,DX,SI,DL,SP或BP
  • 8位: AH,AL,BH,BL,CH,CL,DH或DL
MOV AX,BX;//将数据从BX复制到AX

如下所示:
在这里插入图片描述

使用寄存器寻址,cpu无需访问内存就可以获取操作数,速度快很多

2.立即寻址(Immediate addressing)

在指令中使用的操作数是常数

MOV AX,1234H;//这里的1234H表示的是16进制数,将1234H复制到寄存器AX

如下所示:
在这里插入图片描述
解释一下:AX寄存器由AH和AL构成。

3.存储器寻址(Mermory addressing)

除了寄存器寻址(寄存器就在cpu中)和立即寻址(操作数就在指令中),其他的几种寻址方式的操作数都在内存单元中。
因此,对于存储器寻址,最重要的就是搞清楚cpu如何确定内存操作数的地址,然后cpu再对该内存单元的操作数进行处理。

3.1 直接寻址(direct addressing)

直接寻址就是指令中直接给出了内存操作数的地址。
指令中使用变量时,就是直接寻址
在翻译成机器指令后,变量是用它的地址而不是名字来表示的。
地址外面加上一对方括号,表示取这个地址的内容。

MOV AL,DS:[2000H];

在这里插入图片描述

3.2 寄存器间接寻址(register indirect addressing)

寄存器间接寻址就是指:内存操作数的地址放在了寄存器中

MOV AX,[BX];

在这里插入图片描述

3.3 寄存器相对寻址(register relative addressing)

寄存器相对寻址方式的操作数,其地址是寄存器和一个立即数相加后得到的结果

MOV AL,[BX+5];

在这里插入图片描述

解释一下:

EA:有效地址寄存器,表示操作数所在单元到段首的距离即逻辑地址的偏移地址

3.4 基址加变址寻址(base-plus-index addressing)

基址加变址寻址方式的操作数,其地址是两个寄存器相加得到的结果。这里的两个寄存器分别称之为基址寄存器和变址寄存器
在8086/8088/80286等16位的cpu中:
基址寄存器:BX和BP
变址寄存器:SI和DI
在80386及以后的32位cpu中:
基址寄存器:EAX,EBX,ECX,EDX,ESI,EDI,EBP和ESP
变址寄存器:EAX,EBX,ECX,EDX,ESI,EDI和EBP

MOV AL,[BX+SI];

在这里插入图片描述

3.5 相对基址变址寻址(base relative-plus-index addressing)

基址变址相对寻址方式的操作数,其地址是两个寄存器以及一个立即数相加后得到的结果。

MOV AL,[BX+SI+4];
3.6 比例变址寻址(scaled-index addressing)

地址=基址寄存器+变址寄存器*[1|2|4|8]+相对量

MOV EDI,[ESI+EBX*2+4];

三、总结

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_47138646/article/details/121983236