基址变址寻址和相对基址变址寻址的区别

基址变址寻址和相对基址变址寻址的区别

基址变址寻址(Base-Index Addressing)和相对基址变址寻址(Base-Relative Plus Index Addressing)是两种不同的内存寻址方式。它们在汇编语言和低级编程中常见,用于确定操作数的内存地址。下面是两者的区别:

基址变址寻址(Base-Index Addressing):

  • 这种寻址方式使用两个寄存器:一个是基址寄存器,另一个是变址寄存器。
  • 基址寄存器通常包含一个指向数据段开始的指针。
  • 变址寄存器包含一个偏移量,这个偏移量是相对于数据段开始位置的。
  • 最终的地址是基址寄存器的内容加上变址寄存器的内容。
  • 这种寻址方式允许通过改变变址寄存器的值来访问数据段内的不同位置,非常适用于实现数组和其他数据结构。

例:
其偏移地址是指令中指定的基址寄存器和变址寄存器的内容
2个基址寄存器与2个变址寄存器组合有四种:
[BX+SI] 或写成:[BX] [SI]
[BX+DI]
[BP+SI]
[BP+DI]

相对基址变址寻址(Base-Relative Plus Index Addressing):

  • 这种寻址方式在基址变址寻址的基础上增加了一个常数偏移量(Displacement)。
  • 它同样使用两个寄存器:基址寄存器和变址寄存器。
  • 除了基址和变址寄存器的值,还会加上一个编译时已知的常数偏移量。
  • 这种方法允许更灵活地访问数据结构中的元素,因为它可以在运行时通过变址寄存器和在编译时通过常数偏移量定位到数组或结构体中的特定元素。

例:

MOV CL, [BX+SI+10]

有效地址=BX/BP+SI/DI+8/16位位移量

段地址对应BX基址寄存器默认是DS,对应BP基址寄存器默认是SS;可用段超越前缀改变

用云无忧
© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容