一、首先

P33:

严格来说有三种寻址方式

  1. 与数据有关的寻址方式
  2. 与转移指令或过程调用指令有关的寻址方式
  3. 与IO指令有关的寻址方式

这篇博客只讲1.2两条

二、然后

1. 与数据有关的寻址方式

数据,这个东西主要来自寄存器立即数内存,知道这个,就比较好办了
以下表格顺序与书本中不同。

寻址方式 讲解
立即寻址 指令所需的操作数直接包含在指令代码中,就是常说的立即数
注意,立即数有8/16位两种,在使用时要求与另一个操作数长度匹配
且只能出现在源操作数位置
直接寻址 操作数来源于(指令中直接指出的地址所指向的内存)
MOV AX [2000H],这个方括号的意思是“以括号内的值作为地址,(所指向的内存)中存储的值”
MOV AX,x这里的这个x是之前在数据段定义的变量,当汇编程序被汇编时,汇编器会计算出x的偏移值,然后替换掉原来的x
所以在DEBUG模式下,看到的就不是变量名,而是变量名在数据段中的偏移地址
寄存器寻址 操作数来源于某个寄存器/是这个寄存器里存储的值
比如我要把某个16位的数从BX复制到AX,那么我可以用MOV AX,BX
这里的两个操作数都是寄存器寻址
寄存器间接寻址 这就很好理解了,现在括号里放的不是立即数了,放的是寄存器了,代表操作数在内存中,它的地址的括号内的寄存器中
不过这个间接寻址有几个注意点:
1. 寄存器一般使用的是基址寄存器BP\BX或变址寄存器SI\DI
2. 完整的形式应该是[段地址]:[段内偏移]
3. 当未显式指定段寄存器时,BX\SI\DI中是相对于DS段的偏移地址,BP是相对于SS段的偏移地址
寄存器相对寻址 操作数的地址 = 间址寄存器+偏移量
同直接寻址一样,偏移量可以是一个常量也可以是一个符号名或变量名
例如MOV AX,[SI+10H]MOV AX,ARRAY[SI]
基址变址寻址 操作数地址 = 基址寄存器+变址寄存器
例如MOV AX,[BX+SI]

2.与转移地址有关的寻址方式

这四种寻址方式主要运用于转移指令JMP和过程调用指令CALL
首先要了解这两个东西:
标号,过程名(自己看,不讲了)

寻址方式 讲解
段内直接 就是说我们现在程序运行到这里需要发生一个转跳
去执行其他地方的一些代码
辣么这些代码在哪里呢
我们进行了一些运算,用当前IP的值加上指令中指定的偏移量,得到了一个地址
然后我们就要跳到那里去
比如JMP func1
偏移量可以是8位或者16位,相对的我们就要使用 SHORT func1或者NEAR PTR func1
段间直接 这个和段内直接的区别是什么呢
就是一个X86汇编程序,可能有几个代码段,当使用段间直接寻址时,需要改变段地址的值,相当于跳到了另一个代码段,开始执行新的代码
比如JMP FAR PTR func1
段内间接 跟段内直接的区别是:要转跳的地址放在了寄存器里,而不是一个标号(参考一下2里的寄存器简介寻址吧)
段间间接 类似于段内间接,但是,间接寻址的地址不能直接放在寄存器里,只能放在内存单元中,而且是一个双字

可以简单看看这个博客:
https://blog.csdn.net/b_h_l/article/details/28866267

X86主要的几种寻址方式的更多相关文章

  1. ARM的九种寻址方式

    文章目录 1.立即数寻址 2.寄存器寻址 3.寄存器间接寻址 4.寄存器偏移寻址 5.寄存器基址变址寻址 6.批量寄存器寻址 7.相对寻址 8.堆栈寻址 9.块拷贝寻址 寻址方式就是CPU根据指令中的 ...

  2. ARM寄存器的8种寻址方式01

    一.立即数寻址 操作数由指令本身给出 MOV r0,#0x0F //是所有寻址方式里面速度最快的,但是受到合法立即数的限制 立即数要求以#和$开头 十六进制,#后跟0x:十进制,#后直接加:八进制,# ...

  3. ARM的9种寻址方式

    立即寻址 操作数是立即数,以“#”为前缀,表示 16 进制数值时以“0x”表示. 例: MOV   R0,#0xFF00   ;0xFF00 ->  R0 SUBS   R0,R0,#1     ...

  4. ARM 内核 汇编指令 的 8种 寻址方式

    str: store register ->指令将寄存器内容存到内存空间中, ldr:  load register 将内存内容加载到通用寄存器, ldr/str 组合来实现ARM CPU 和内 ...

  5. X86 寻址方式、AT&T 汇编语言相关知识、AT&T 与 Intel 汇编语言的比较、gcc 嵌入式汇编

    注:本分类下文章大多整理自<深入分析linux内核源代码>一书,另有参考其他一些资料如<linux内核完全剖析>.<linux c 编程一站式学习>等,只是为了更好 ...

  6. C语言的本质(29)——C语言与汇编之寄存器和寻址方式

    x86的通用寄存器有eax.ebx.ecx.edx.edi.esi.这些寄存器在大多数指令中是可以任意选用的,比如movl指令可以把一个立即数传送到eax中,也可传送到ebx中.但也有一些指令规定只能 ...

  7. x86汇编程序基础(AT&T语法)

    一.简单的汇编程序 以下面这段简单的汇编代码为例 .section .data .section .text .globl _start _start: movl $, %eax movl $, %e ...

  8. X86/X64处理器体系结构及寻址模式

    由8086/8088.x86.Pentium发展到core系列短短40多年间,处理器的时钟频率差点儿已接近极限.尽管如此,自从86年Intel推出386至今除了添加一些有关流媒体的指令如mmx/sse ...

  9. x64汇编第二讲,复习x86汇编指令格式,学习x64指令格式

    目录 x64汇编第二讲,复习x86汇编指令格式,学习x64指令格式 一丶x86指令复习. 1.1什么是x86指令. 1.2 x86与x64下的通用寄存器 1.3 OpCode 1.4 7种寻址方式 二 ...

随机推荐

  1. 支付宝即时到账接口开发 - DEMO讲解

    支付宝即时到帐接口 环境要求 PHP5.0以上,且需要开启curl.openssl. 文档地址: https://doc.open.alipay.com/doc2/detail?treeId=62&a ...

  2. Null和undefined的区别?

    (1)null是一个表示”无”的对象,转我数值是为0,undefined是一个表示”无”的原始值,转为数值时为NaN.当声明的变量还未被初始化时,能量的默认值为undefined (2)Null用来表 ...

  3. SQL必知必会摘要

    数据检索 2.2 检索单个列 SELECT prod_name FROM Products; SQL语句不区分大小写   2.3 检索多个列 SELECT prod_name,prod_id,prod ...

  4. Python2.7-shutil

    shutil 模块,高级文件操作模块,支持文件或文件夹的复制和删除 模块方法: shutil.copyfileobj(fsrc, fdst[, length]):将类文件对象(在python中打开的文 ...

  5. Java中 Vector的使用详解

    Vector 可实现自动增长的对象数组. java.util.vector提供了向量类(Vector)以实现类似动态数组的功能. 创建了一个向量类的对象后,可以往其中随意插入不同类的对象,即不需顾及类 ...

  6. C#构造方法--实例化类时初始化的方法

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...

  7. timestamp 字段

    项目中由于需求设计,数据库中需要一个timestamp时间戳类型的字段来作为区别数据添加和修改的标识.由于timestamp在SQL SERVER 2005数据库中,不可为空的timestamp类型在 ...

  8. java中CyclicBarrier简单入门使用

    一个同步辅助类,它同意一组线程互相等待,直到到达某个公共屏障点 (common barrier point). 在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待.此时 CyclicBarr ...

  9. ME_PROCESS_PO_CUST 实现采购订单行项目增强

    用户希望创建采购订单时,输入行项目时,能根据采购订单类型,自动带出科目分类类别. 业务顾问看了一下配置,不能实现这个功能,所以用增强实现. 采购订单BADI增强:ME_PROCESS_PO_CUST. ...

  10. EZ 2018 04 06 NOIP2018 模拟赛(七)

    我是链接 这次是真的惨,码了将近2hours的可持久化线段树炸掉了! 而且本地拍了一万年也没发现哪里炸了. T1 压位的入门题,话说这道题能拿个99分就可以了(100分要FFT) 对于暴力,就是暴力找 ...