IA32体系结构2(x86寻址方式)

2024-02-21 23:32

本文主要是介绍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寻址方式)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/733442

相关文章

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初