前言
人呢自己做的选择无论好与坏都不要后悔呢,因为即使错误的选择也可能是人生美好的风景。
寻址方式
首先来说一下汇编的指令的构成:一条指令一般由操作码和操作数构成,操作码说明的是当前的这条指令是干啥的,操作数就是操作码操作的数据。
寻址方式: 就是寻找指令中所需操作数的各种方法,也就是提供指令中操作数存储信息的方式。
Intel 8086/8088提供操作数的方法
- 立即数操作数:操作数在指令代码中提供。
- 寄存器操作数:操作数在cpu的通用寄存器或者是段寄存器中
- 存储器操作数:操作数在内存的存储单元中。
- I/O端口操作数:操作数在输入/输出的接口的寄存器中。
立即数寻址(只能作为源操作数不能作为目的操作数)
立即数寻址方式的指令中,所需要的操作数直接包含在指令代码中,这种操作数称为立即数,
由于指令在执行的过程中,立即数作为指令的一部分直接从biu的指令队列中取出,不需要额外的线程周期,因此这种寻址方式执行速度快。
寄存器寻址
寄存器寻址方式是指指令中所需要的操作数在CPU的某个寄存器中,可以是通用寄存器也可以是段寄存器。
- 寄存器间接寻址:操作数的有效地址EA直接从某个基址寄存器(BX,BP)或者是变址寄存器(SI,DI)中获取,寄存器间接寻址就是事先将偏移量存放在某个寄存器(BX,BP,SI,DI)中,这些寄存器就如同一个地址指针,操作内存的具体示意图如下。
寄存器的默认使用规则 SP使用SS其余使用的是DS,这种寻址方式是对存储器操作时候使用的
-
基址/变址寻址:操作数的有效地址EA等于基址分量或变址分量加上指令中给出的位移量,内存的具体操作示意图如下。
寄存器的默认使用规则 SP使用SS其余使用的是DS,这种寻址方式是对存储器操作时候使用的
- 基址变址寻址:操作数的有效地址是三个地址分量之和,内存访问示意图如下。
寄存器的默认使用规则 SP使用SS其余使用的是DS,这种寻址方式是对存储器操作时候使用的
存储器的操作数寻址方式的地址总结
对于程序对内存的访问就是通过在CS,DS,SS,ES获取段基址,通过寄存器的寻址方式获取有效地址EA,通过二者获取到要操作的内存地址
串操作寻址方式
8086/8088设置有专门用于串操作的指令,这些指令的操作数虽然也在存储器中,但是他们不使用前面介绍的各种寻址方式,而是隐含地使用变址寄存器SI/DI专门指示,在寻找操作数的时候,使用SI作为原操作数的地址指针,DI作为目的串的操作指针,在串操作完成自动对SI和DI进行修改。
I/O端口寻址
- 存储器编址方法:将I/O端口视为存储器的一个单元,对端口的访问就如同访问存储器单元一样,访问存储器的指令和各种寻址方式同样适用于I/O端口的访问。
- I/O端口编址方法:I/O端口的地址于存储器的地址分开,并使用专门的输入指令和输出指令(8086/8088使用的就是这种方式)
(1)直接端口寻址:在指令中直接给出输入或者是输出的端口,端口地址一般是2位的16进制数,也可以用符号表示,直接寻址可访问的端口数为 0~255
(2)寄存器间接寻址:就是把I/O端口的地址先放到DX中,用DX作为间接寻址寄存器(大于255必须使用这种方式)。