在32位微机系统中,除了支持前面的七种寻址方式外,又提供了一种更灵活、方便,但也更复杂的内存寻址方式,从而使内存地址的寻址范围得到了进一步扩大。

在用16位寄存器来访问存储单元时,只能使用基地址寄存器(BX和BP)和变址寄存器(SI和DI)来作为地址偏移量的一部分,但在用32位寄存器寻址时,不存在上述限制,所有32位寄存器(EAX、EBX、ECX、EDX、ESI、EDI、EBP和ESP)都可以是地址偏移量的一个组成部分。

当用32位地址偏移量进行寻址时,内存地址的偏移量可分为三部分:一个32位基址寄存器,一个可乘1、2、4或8的32位变址寄存器,一个8位/32位的偏移常量,并且这三部分还可进行任意组合,省去其中之一或之二。

32位基址寄存器是:EAX、EBX、ECX、EDX、ESI、EDI、EBP和ESP;
32位变址寄存器是:EAX、EBX、ECX、EDX、ESI、EDI和EBP(除ESP之外)。

下面列举几个32位地址寻址指令:

MOV AX, [123456H]
 MOV EAX, [EBX]
MOV EBX, [ECX*2]
 MOV EBX, [EAX+100H]
MOV EDX, [EAX*4+200H]
 MOV EBX, [EAX+EDX*2]
MOV EBX, [EAX+EDX*2+300H]
 MOV AX, [ESP]

用32位地址偏移量进行寻址的有效地址计算公式归纳如公式所示。

由于32位寻址方式能使用所有的通用寄存器,所以,和该有效地址相组合的段寄存器也就有新的规定。具体规定如下:

1、地址中寄存器的书写顺序决定该寄存器是基址寄存器,还是变址寄存器;

如:[EBX+EBP]中的EBX是基址寄存器,EBP是变址寄存器,而[EBP+EBX]中的EBP是基址寄存器,EBX是变址寄存器;

2、默认段寄存器的选用取决于基址寄存器;

3、基址寄存器是EBP或ESP时,默认的段寄存器是SS,否则,默认的段寄存器是DS;

4、在指令中,如果使用段前缀的方式,那么,显式段寄存器优先。

下面列举几个32位地址寻址指令及其内存操作数的段寄存器。

指令的举例 访问内存单元所用的段寄存器
MOV  AX, [123456H] ;默认段寄存器DS
MOV  EAX, [EBX+EBP] ;默认段寄存器DS
MOV  EBX, [EBP+EBX] ;默认段寄存器SS
MOV  EBX, [EAX+100H] ;默认段寄存器DS
MOV  EDX, ES:[EAX*4+200H] ;显式段寄存器ES
MOV  [ESP+EDX*2], AX  ;默认段寄存器SS
MOV  EBX, GS:[EAX+EDX*2+300H] ;显式段寄存器GS
MOV  AX, [ESP]  ;默认段寄存器SS

32位地址的寻址方式相关推荐

  1. 七种寻址方式(32位地址的寻址方式)

    在32位微机系统中,除了支持前面的七种寻址方式外,又提供了一种更灵活.方便,但也更复杂的内存寻址方式,从而使内存地址的寻址范围得到了进一步扩大. 在用16位寄存器来访问存储单元时,只能使用基地址寄存器 ...

  2. 32位单片机 一个32位地址代表一个字节而不是4个字节(32位)

    在数据手册上,BSRR的偏移地址为0X18,然后手册讲完BSRR后直接讲LCKR了,并且LCKR的偏移地址是 OX1C .所以根据 OX1C-0X18=0X04 就知道BSRR是32位寄存器了.因为一 ...

  3. 使用 Visual Basic 通过 32 位 地址访问内存(中英对照)

    使用 Visual Basic 通过 32 位 地址访问内存 2001年7月6日 马尼拉,菲律宾 作者:Chris Vega [gwapo@models.com] 当我们谈论"真的" ...

  4. 32位地址为什么是4GB

    32为地址,存储器可寻址空间为4GB,即0x0000,0000~0xFFFF,FFFF.为什么? 第一步:0x0000,0000~0xFFFF,FFFF 相当于  2的32次方 个地址. 第二步:2的 ...

  5. 32位java 最大内存_【答疑系列】为什么32位系统只支持最大4G内存?

    这个问题一直都有同学问到,算是提问次数最多的问题之一了. 32位是什么 现在主流的操作系统都是64位的,早期存在32位操作系统,相信大家也都有所听闻,其实,在更早之前,还有16位.8位的,这里就不展开 ...

  6. ASM:《X86汇编语言-从实模式到保护模式》第10章:32位x86处理器的编程架构

    ★PART1:32位的x86处理器执行方式和架构 1. 寄存器的拓展(IA-32) 从80386开始,处理器内的寄存器从16位拓展到32位,命名其实就是在前面加上e(Extend)就好了,8个通用寄存 ...

  7. 10、32位 x86处理器编程架构

    10.1.IA-32架构的基本执行环境 10.1.1.寄存器的扩展 8个通用寄存器的扩展:(AX.BX.CX.DX) 16位 -> 32位 (EAX.EBX.ECX.EDX)(SI.DI.BP. ...

  8. 707-详解32位Linux系统内存地址映射

    详解32位Linux系统内存地址映射 我们先看一段简单的C程序: 我们先来看一张图: 我们平时所说的x86 32位指的是:80386往后到现在的同一个体系的CPU处理芯片,但是x86这个芯片是从808 ...

  9. 16位模式/32位模式下PUSH指令探究——《x86汇编语言:从实模式到保护模式》读书笔记16...

    一.Intel 32 位处理器的工作模式 如上图所示,Intel 32 位处理器有3种工作模式. (1)实模式:工作方式相当于一个8086 (2)保护模式:提供支持多任务环境的工作方式,建立保护机制 ...

最新文章

  1. [NOI2002] 银河英雄传说(带权并查集好题)
  2. FPGA作为从机与STM32进行SPI协议通信---Verilog实现
  3. libevent和libev的区别对比(二)
  4. ASP.NET Core 1.1 Preview 1 简介(包含.NETCore 1.1升级公告)
  5. 【PAT甲级 删除字符串中的指定字符】1050 String Subtraction (20 分) C++
  6. java分支语句有哪些_Java代码多分支语句优化
  7. 如何在JS中应用正则表达式
  8. jQuery Ajax - ajax()方法,参数注释
  9. 英语总结系列(二十二):Baby偶遇GCT
  10. 2010年一月份兑换公告
  11. LeetCode——N-Queens II
  12. 四轴飞行器的设计与开发过程
  13. 【Android】mina框架使用详情
  14. Mac下nginx配置虚拟主机,访问报错502
  15. 2021 Summary
  16. 武汉大学IT职业培训
  17. 译文Deep Learning in Bioinformatics --深度学习在生物信息学领域的应用(1)
  18. 微信的NATIVE支付提示201商户订单号重复的解决方案
  19. 如何用W7100A实现串口转以太网(一)
  20. Flask-自定义头像

热门文章

  1. 【ijkplayer】编译 Android 版本的 ijkplayer ④ ( 安装 make yasm 软件 | 执行 compile-ffmpeg.sh all 命令编译 ffmpeg )
  2. 【Android 逆向】整体加固脱壳 ( DexClassLoader 加载 dex 流程分析 | DexFile loadDexFile 函数 | 构造函数 | openDexFile 函数 )
  3. 【Windows 逆向】CE 地址遍历工具 ( CE 结构剖析工具 | 遍历查找后坐力数据 | 尝试修改后坐力数据 )
  4. 【Flutter】Flutter 混合开发 ( 安卓端向 Flutter 传递数据 | FlutterFragment 数据传递 | FlutterActivity 数据传递 )
  5. 【FFmpeg】ffmpeg 命令查询二 ( 比特流过滤器 | 可用协议 | 过滤器 | 像素格式 | 标准声道布局 | 音频采样格式 | 颜色名称 )
  6. 【运筹学】线性规划 单纯形法 ( 原理 | 约定符号 | 目标系数矩阵 C | 目标函数变量矩阵 X | 约束方程常数矩阵 b | 系数矩阵 A | 向量 | 向量符号 | 向量 Pj )
  7. 第1次作业+105032014074
  8. typeof和instanceof 运算符
  9. 20145228《Java程序设计》课程总结
  10. 数组作为函数参数进行传递