汇编的寻址方式
•操作数可以存在什么地方?
操作数存在于指令代码中,处理器译码时就立即获得了这个操作数,这就是立即(数)寻址方式。汇编指令中,这个立即数(操作数)以常量形式出现 •操作数存在于处理器内部寄存器中,处理器从寄存器中获得这个操作数,这就是寄存器寻址方式。汇编指令中,这个寄存器操作数以寄存器名形式出现 •操作数存在于主存中,处理器从主存单元获得这个操作数,这就是存储器寻址方式。汇编指令中,这个存储器操作数以主存地址形式出现。
•8086/8088处理器的主存地址在程序设计时采用逻辑地址。逻辑地址分成段地址和偏移地址两部分。
存储器寻址方式表达存储器地址时,段地址在默认的或段超越前缀指令指定的段寄存器中,偏移地址被称为有效地址EA(Effective Address)。有效地址用中括号括起来。
•有多种获得偏移地址的方法,所以存储器寻址方式又分成多种寻址方式。
–有效地址直接给出,存在于指令代码中,就是直接寻址方式
–有效地址存在寄存器中,就是通过寄存器的间接寻址方式
–有效地址是两部分的和,一部分在寄存器中,另一部分直接给出(称为位移量),这就是寄存器相对寻址方式
–有效地址是两部分的和,一部分在基址寄存器中(8086是BX和BP),另一部分在变址寄存器中(8086是SI和DI),
–有效地址是三部分的和,第一部分在基址寄存器中(8086是BX和BP),第二部分在变址寄存器中(8086是SI和DI),
•区别各种寻址方式时,注意各自的特点:
•只有一个常量,
•只有一个寄存器名,
•其他
•用中括号括起一个常量
•用中括号括起一个寄存器名,是寄存器间接寻址方式;
•用中括号括起一个寄存器名和一个常量
•用中括号括起两个寄存器名和一个常量
•汇编语句中,还有其他形式出现,需要理解相应操作符才能做出正确判断。
例如
•直接写出变量名实际上
•
•变量名和一个寄存器
•利用offset后跟一个变量名
•8086/8088有7种基本的寻址方式:
立即寻址,
寄存器寻址,
直接寻址,
寄存器间接寻址,
寄存器相对寻址,
基址加变址寻址方式,
相对基址加变址寻址。
•立即数寻址
操作数就在指令中,作为指令的一部分,跟在操作码后存放在代码段。
mov ah,01h
mov ax,1204h
;如果立即数是16位的,则高地址放在高位,低地址放在低位
•寄存器寻址
操作数在寄存器中,指令中指定寄存器号。对于8位操作数,寄存器可以是AL,AH,BL,BH,
CL,CH,DL,DH。 对于16位操作数,寄存器可以是AX,BX,CX,DX,BP,SP,SI,DI等
mov ah,ch
mov bx,ax
•直接寻址方式
操作数在存储器中,指令直接包含操作数的有效地址EA。
mov ax,[1122h] ;将ds:1122的数据放在ax,默认段为DS
mov es:[1234],al ;采用了段前缀
•寄存器间接寻址
操作数在存储器中,操作数的有效地址在SI,DI,BX,BP这4个寄存器之一中。在不采用段前
缀的情况下, 对于DI,SI,BX默认段为DS,而BP为SS。
mov ah,[bx]
mov ah,cs:[bx] ;使用了段前缀
•寄存器相对寻址
操作数在存储器中,操作数的有效地址是一个基址寄存器(BX,BP)或变址寄存器(SI,DI)的
内容加上8位或16位的位移之和。在指令中的8位和16位的常量采用补码表示,8位要被带
符号扩展为16位。
mov ah,[bx+6]
;段址默认情况与寄存器间接寻址相同
•基址加变址寻址
操作数在存储器中,操作数的有效地址是一个基址寄存器(BX,BP)加上变址寄存器(SI,DI)的
内容。如果有BP,则默认段址为SS,否则为DS.
mov ah,[bx+si]
•相对基址加变址寻址
操作数在存储器中,操作数的有效地址是一个基址寄存器(BX,BP)和变址寄存器(SI,DI)的
内容加上8位或16位的位移之和。如果有BP,则默认段址为SS,否则为DS.
mov ax,[bx+di-2]
mov ax,1234h[bx][di]
[注]:上面3~7为存储器寻址方式
线面给出一张图片,个人认为结合图片在理解8086的寻址方式就会更简单: