本文主要是介绍IA32体系结构2(x86寻址方式),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
数据寻址方式
8086~80286微处理器的数据寻址方式包括:
1.寄存器寻址
2.立即寻址
3.直接寻址
4.寄存器间接寻址
5.基址加变址寻址
6.寄存器相对寻址
7.相对基址加变址寻址
80386以上处理器还包括:
8.比例变址方式的存储器数据寻址
一些说明
这么多的寻址方式,有些比较直观,有些就很头大,什么叫基址加变址寻址?这要从x86的寄存器说起,话说x86有8个通用寄存器:EAX、EBX、ECX、EDX、EBP、ESP、ESI、EDI。其实每个寄存器,都是有相对特定的用途的,只是不是所有用途都是强制规定,每个寄存器的常见用途如下:
1.EAX-累加器
2.EBX-基址:EBX用于保存访问存储单元的偏移地址。
3.ECX-计数器:可以保存很多指令需要用到的计数值,比如串指令、移位指令、loop指令。
4.EDX-数据
5.EBP-基址针
6.ESI-源变址
7.EDI-目标变址
8.ESP-栈指针
所以,所谓的基址加变址寻址就是以EBX(BX)或者EBP(BP)加上EDI或者ESI的寻址方式。这样一来,我们基本能明白,那么多的寻址方式是怎么回事了。说到底,数据寻址方式,就是如何寻址数据的一些方法。无非就是寄存器到寄存器、寄存器到存储器、存储器到存储器之间的数据传送,这些传送方式需要遵循一定的规则,不是想怎么传就能怎么传的,比如,不是所有指令都支持存储器到存储器的数据传送的。这应该是由cpu设计决定的,还无法做到任意数据单元之间的任意数据搬移。
数据寻址方式详解
以mov指令为例,详细说明各种寻址方式是怎么回事,首先看下mov指令格式:
MOV AX,BX
intel标准汇编格式,源操作数在右边,目标操作数在左边。其中MOV是操作码。这条指令,将BX寄存器内容复制到AX寄存器中。
1.寄存器寻址
把一个字节/字/双字的副本从源操作数寄存器或者存储单元传送到目标操作数寄存器或者存储单元。比如:
mov cx,dx
讲dx寄存器的内容复制到cx寄存器中。
2.立即寻址
将源立即数传送到目标寄存器或者存储单元。比如:
mov ebx, 12345678H
将双字数据12345678H复制到ebx寄存器中。
3.直接寻址
在存储单元和寄存器之间传送字节/字/双字。比如:
mov cx,LIST
将存储单元LIST的字内容复制到寄存器cx中。
4.寄存器间接寻址
在寄存器和存储单元之间传送数据,而存储单元由变址或者基址寄存器寻址。变址和基址寄存器是BP、BX、DI、SI。比如:
mov ax, [bx]
将数据段中BX寄存器内容作为偏移地址的存储单元的数据复制到寄存器ax中。
5.基址加变址寻址
在寄存器和存储单元之间传送一个字节/字/双字,该存储单元由基址寄存器(BP或BX)加变址寄存器(DI或SI)寻址,比如:
mov [bx+di], cl
将寄存器cl的字节内容复制到数据段中BX加DI寻址的存储单元中。
6.寄存器相对寻址
在寄存器和变址寻址的存储单元或基址寄存器加位移量寻址的存储单元之间传送数据。比如:
mov ax,[bx+4]或者mov ax,ARRAY[bx]
第一条指令将数据段中由bx加4寻址的单元的内容装入ax。第二条指令将数据段中由ARRAY加bx内容寻址的存储单元中的数据装入ax。
7.相对基址加变址寻址
在寄存器和存储单元之间传送数据,该存储单元是由基址寄存器加变址寄存器再加位移量寻址的。比如:
mov ax, ARRAY[bx+di]
用ARRAY,bx和di相加形成存储单元地址,将该地址处的字数据装入ax。
8.比例变址寻址
这种寻址方式只能用于80386以上微处理器。对寄存器中的第二个寄存器内容用2倍、4倍或8倍比例因子修改,产生操作数的存储器地址,比如:
mov edx,[eax+4*ebx]
将数据段中地址为eax加上4倍ebx的存储单元的内容装入edx。
以上信息来源《intel微处理器结构、编程与接口》第六版
这篇关于IA32体系结构2(x86寻址方式)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!