作者:yiqing020308 | 来源:互联网 | 2023-10-14 12:44
存储器寻址方式是什么?
寻址方式给我们提供了“在存储器中找到/存放操作数的方法“,即告知我们”如何寻找到存取操作数(数据)的存储器内存单元“。
既然操作数表征着数据的来源和去向,那么我们可以这么认为“寻址方式就是使用某种方式(直接/间接)告诉我们一个内存单元的地址,我们通过这个地址可以找到或者存放数据“。
切记:寻址方式寻找的是“存储器内存单元的地址“,由于地址获取方式不同,因此产生了不同的寻址方式。
存储器寻址方式涉及到的寄存器
基址寄存器:BX(基址寄存器)、BP(基址指针寄存器)
这两个寄存器主要用于寄存器相对寻址(MOV AX [BX+5]),寄存器间接寻址(MOV AX [BX]);
变址寄存器:SI(源变址寄存器)、DI(目标变址基础器)
这两个寄存器主要用于寄存器基址变址相对寻址(MOV AX [SI+BX+5]),寄存器基址变址寻址(MOV AX [BX+SI])。
特别要注意的是“基址变址”寻址的含义是“DI/SI+BX/BP”,即两个加数中必须一个是基址寄存器,另一个是变址寄存器,并且不存在基址基址寻址(不存在MOV AX [BP+BX]),变址变址寻址(不存在MOV AX [SI+DI])。
存储器寻址方式的分类
我们还是以MOV指令为例说明以上寻址方式:
1. 直接寻址/立即数寻址:MOV AX [1200H]
我们通过直接指明存储器单元的地址,告知系统源操作数存放的具体位置。
2. 间接寻址之寄存器寻址方式:MOV AX [BX]
如果源操作数为寄存器,系统将会对寄存器内的内容进行操作,同样的,如果目标操作数为寄存器,系统将会将计算后的数据存放入寄存器中。“MOV AX [BX]“中BX的内容代表一个存储器内存单元的地址。我们将这种”通过寄存器告知系统操作数存储地址“的方式称为“间接寻址之寄存器寻址方式”。
3. 间接寻址之寄存器相对寻址方式:“MOV AX [BX]5”或者“MOV AX [BX+5]”
“相对”一词的含义:目标内存单元相对于BX中存放的基地址偏移指定个数的内存单元。“MOV AX [BX]5”或者“MOV AX [BX+5]”都代表了“目标内存单元位置相对于BX中存放的基地址偏移了5个内存单元”。
4. 间接寻址之寄存器基址变址寻址:“MOV AX [BX+SI]”或者“MOV AX [BX][SI]”
“基址变址寻址”中涉及到了两类寄存器“基址寄存器和变址寄存器”,这类寻址方式一般用于一维数组的遍历。
5. 间接寻址之寄存器基址变址相对寻址:“MOV AX [BX+SI]5”或者“MOV AX [BX+SI+5]”或者“MOV AX [BX][SI+5]”或者“MOV AX [BX+5][SI]”或者“MOV AX [BX][SI]5”
“基址变址相对寻址”中涉及到了两类寄存器“基址寄存器和变址寄存器”以及立即数,这类寻址方式一般用于二维数组的遍历。
注意:基址变址相对寻址不可以写为“MOV AX [BX][SI][5]”,其与“MOV AX [BX][SI]5”有着本质的区别。假设BX内容为1024H,SI内容为100,数据段中第五个内存单元(DS:[5])中内容为20那么
[BX][SI][5]代表的数据段偏移地址为“1024H+100+20“;
[BX][SI]5代表的数据段偏移地址为“1024H+100+5“;
在存储器中只要加了[]中括号,中括号中的内容就代表着存储器中逻辑段的偏移地址。
存储器寻址中的段重映射
在知道了内存单元相对于逻辑段段首的偏移地址之后,我们再分析一下内存单元到底在哪个逻辑段。此时,我们要从基址寄存器入手:BX代表基址寄存器,如果BX出现则代表数据默认在数据段DS中;BP代表基址指针寄存器,如果BP出现则代表数据默认在堆栈段SS。此外,直接寻址”MOV AX [1024H]”在默认情况下代表了数据段DS的偏移地址。
我们可以显式的指定内存单元所在的逻辑段吗?
可以的,这里需要我们使用段重设的方式来改变“基于基址寄存器BX/BP的默认属性“。我们再以MOV指令进行说明:
1. 直接寻址中的段重设:(从默认数据段重映射至附加段)
”MOV AX [1024H]”->”MOV AX ES:[1024H]”
将附加段中偏移地址为1024H的内存单元内容存放入AX寄存器中;
2. 寄存器间接寻址中的段重设:(从默认数据段重映射至附加段)
”MOV AX [BX]”->”MOV AX ES:[BX]”
BX的内容代表了内存单元的偏移地址,将附加段中偏移地址为BX内容的内存单元内容存放入AX寄存器中;
3. 寄存器相对寻址中的段重设:(从默认数据段重映射至附加段)
”MOV AX [BX+5]”->”MOV AX ES:[BX+5]”
BX的内容代表了内存单元的偏移地址,将附加段中偏移地址为“BX内容+5“的内存单元内容存放入AX寄存器中;
4. 寄存器基址变址相对寻址中的段重设:(从默认数据段重映射至附加段)
”MOV AX [BX+SI+5]”->”MOV AX ES:[BX+SI+5]”
BX的内容代表了内存单元的偏移地址,SI的内容也代表了内存单元的偏移地址,将附加段中偏移地址为“BX寄存器内容+SI寄存器内容+5“的内存单元内容存放入AX寄存器中;
存储器操作数字长的限定
存储器操作数字长和立即数操作数字长可以为任意大小,但是操作码对数据操作时要求两个操作数字长等大并且必须知道至少一个操作数的字长。在存储器操作数、立即数操作数(立即数操作数在高位补0,数值大小并没有发生改变但是立即数的字长却变了,例如8050H和08050H数值一样,但是8050H和08050H字长却不相等)、寄存器操作数中,之后寄存器操作数字长固定(8位或者16位)。
1. 操作数中有寄存器操作数(可以不指定字长)
2. 操作数中没有寄存器操作数(必须使用PTR指令指定字长,8位byte或者16位word)
但是要注意:两个存储器单元不可以使用MOV指令直接进行数据转移!