【MASM汇编语言快速入门】寻址方式速查表

intel风格寻址方式格式速查

0. 段寄存器的使用规定***

访问存储器的方式默认的段寄存器可超越的段寄存器偏移地址
取指令, 跳转?cs不可超越ip
堆栈操作ss不可超越sp
一般数据访问dscs, ss, esea
串操作的源操作数dscs, ss,essi
串操作的目的操作数es不可超越di
bp作为基址的寻址方式sscs, ds, esea

总结:

  1. 取指令只能cs
  2. push,pop只能ss
  3. 串操作目的串只能es
  4. 只要有bp出现默认段寄存器为ss
  5. 只要有bx, si, di出现默认段寄存器为ds

段超越就是指不使用默认的段寄存器, 如ss:[si]就是超越到ss段, 使用默认的段寄存器可以不用写出比如[si]

1. 直接寻址方式

[imm16]

mov ax, [2000h] ; ax << ds:[2000h]

2. 寄存器间接寻址方式

注:
这里的reg16只能取bx, bp, si, di, 其中若取bp则隐含段寄存器为ss, 其余隐含为ds
[reg16]

mov ax, [si] 					; ax << ds:[si]

3. 寄存器相对寻址方式

[reg16 + imm16] 或 imm16[reg16]

注:
这里的reg16只能取bx, bp, si, di, 其中若取bp则隐含段寄存器为ss, 其余隐含为ds

mov ax, [di + 06h]			; ax << ds:[di + 06h]

4. 基址变址寻址方式

[base + reg16] 或 [bx][reg16]

注:
这里的base只能从bx,bp中取(取bx则隐含段寄存器为ds, 取bp则隐含段寄存器为ss)
这里的reg16只能从si, di中取

mov ax, [bx + si]			; ax << ds:[bx + si]

5. 相对基址变址寻址方式

[base + reg16 + imm16] 或 imm16[base][reg16]

注:
这里的base只能从bx, bp中取(取bx则隐含段寄存器为ds, 取bp则隐含段寄存器为ss)
这里的reg16只能从si, di中取
mov ax, [bx + si + 06h] ; ax << ds:[bx + si + 06h]

附录: AT&T风格,Intel风格汇编差异对比

Win家一般使用Intel风格, 开源界和类Unix系统一般使用AT&T风格

1. 寄存器命名 %

AT&T风格中,寄存器会加上%作为前缀.而Intel汇编中寄存器名是不需要加前缀的.可以直接使用.

AT&T风格Intel风格说明
push %eaxpush eax这是一条入栈指令,把寄存器eax中的值压入栈中

2. 立即数格式 $

  • AT&T 汇编中 , 用$前缀表示一个立即数.
  • Intel 汇编中 , 立即数没有任何前缀. 直接用一个数字表示. (当然有不同的进制. 比如 0x01 , 10 等)
AT&T风格Intel风格说明
push $1push 1把一个立即数压入栈中

3. 操作数顺序

AT&T和Intel格式中的源操作数和目标操作数的位置正好相反
下面是给寄存器EAX 赋一个初值1.

  • AT&T风格: 操作符 源操作数 , 目的操作数
    mov $1 , %eax
  • Intel风格: 操作符 目的操作数 , 源操作数
    mov eax , 1
AT&T风格Intel风格说明
push $1push 1把一个立即数压入栈中

4. 内存操作数的寻址方式

  • AT&T寻址格式: section:disp(base, index, scale)
  • Intel 寻址格式: section:[base + index*scale + disp]

无论形式如何,都是实现如下的地址计算:(其中base和index必须是寄存器,disp和scale可以是常数)
disp + base + index * scale
中文释义: 地址或偏移 (%基址或偏移量寄存器, %索引寄存器, 比例因子)
计算方法: 最终地址 = 地址或偏移 + %基址或偏移量寄存器 + %索引寄存器 * 比例因子
寻址参考: AT&T汇编语言及其寻址方式

AT&T格式Intel格式
movl -4(%ebp), %eaxmov eax, [ebp - 4]
movl array(, %eax, 4), %eaxmov eax, [eax*4 + array]
movw array(%ebx, %eax, 4), %cxmov cx, [ebx + 4*eax + array]
movb $4, %fs:(%eax)mov fs:eax, 4

注: 关于寻址中的段寻址知识参考:
目前在Linux环境上,不管是32位还是64位操作系统段寻址都被废弃. 直接使用的线性地址. 不过fsgs在特殊情况下还有使用.

5. 数据宽度表示

  • 在AT&T汇编格式中,操作数的字长由操作符的最后一个字母决定,
    后缀bwl分别表示操作数为字节(byte,8比特)、字(word,16比特)和长字(long,32比特);
  • 而在Intel汇编格式中,操作数的字长是用byte ptrword ptr等前缀来表示的
AT&T格式Intel格式
movb val, %almov al, byte ptr val
  • 24
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值