找回密码
 register

QQ登录

只需一步,快速开始

查看: 17|回复: 0

[汇编语言] [零基础入门学习]·39·数据处理的两个基本问题·寻址方式·指令要处理的数据有多长

[复制链接]

[汇编语言] [零基础入门学习]·39·数据处理的两个基本问题·寻址方式·指令要处理的数据有多长

[复制链接]
  • 打卡等级:热心大叔
  • 打卡总天数:94
  • 打卡月天数:17
  • 打卡总奖励:94
  • 最近打卡:2025-01-18 01:28:20
Waylee

主题

0

回帖

1万

积分

仙帝

积分
11929
Waylee 2025-1-16 14:25 | 显示全部楼层 |阅读模式 | Google Chrome | Windows 10

马上注册,查看网站隐藏内容!!

您需要 登录 才可以下载或查看,没有账号?register

×


8.4 寻址方式

当数据存放在内存中的时候,我们可以用多种方式来给定这个内存单元的偏移地址,这种定位内存单元的方法一般被称为寻址方式。

8086CPU有多种寻址方式,我们在前面的课程中都已经用到了,这里进行下一步总结,如表8.2所列。

表8.2 寻址方式小结

寻址方式 含义 名称 常用格式举例
[idata] EA=(idata); SA=(ds) 直接寻址 [idata]
[bx] EA=(bx); SA=(ds) 寄存器间接寻址 [bx]
[si] EA=(si); SA=(ds) 寄存器间接寻址 [si]
[di] EA=(di); SA=(ds) 寄存器间接寻址 [di]
[bp] EA=(bp); SA=(ss) 寄存器间接寻址 [bp]
[bx+iData] EA=(bx)+idata; SA=(ds) 寄存器相对寻址 用于结构体:[bx].idata
[si+iData] EA=(si)+idata; SA=(ds) 寄存器相对寻址 用于数组:idata[si], idata[di]
[di+iData] EA=(di)+idata; SA=(ds) 寄存器相对寻址 用于二维数组: [bx][idata]
[bp+iData] EA=(bp)+idata; SA=(ss) 寄存器相对寻址
[bx+si] EA=(bx)+(si); SA=(ds) 基址变址寻址 用于二维数组: [bx][si]
[bx+di] EA=(bx)+(di); SA=(ds) 基址变址寻址
[bp+si] EA=(bp)+(si); SA=(ss) 基址变址寻址
[bp+di] EA=(bp)+(di); SA=(ss) 基址变址寻址
[bx+si+iData] EA=(bx)+(si)+idata; SA=(ds) 相对基址变址寻址 用于表格(结构)中的数组项: [bx].idata[si]
[bx+di+iData] EA=(bx)+(di)+idata; SA=(ds) 相对基址变址寻址
[bp+si+iData] EA=(bp)+(si)+idata; SA=(ss) 相对基址变址寻址 用于二维数组: idata[bx][si]
[bp+di+iData] EA=(bp)+(di)+idata; SA=(ss) 相对基址变址寻址

8.5 指定要处理的数据有多长

8086CPU的指令,可以处理两种尺寸的数据,byte和word。所以在机器指令中要指令,指令进行的是字操作还是字节操作。对于这个问题,汇编语言中用以下方法处理。

一、通过寄存器名指明要处理的数据的尺寸。
例如,下面的指令中,寄存器指明了指令进行的是字操作。

mov ax,1
mov bx,ds:[0]
mov ds,ax
mov ds:[0],ax
inc ax
add ax,1000

下面的指令中,寄存器指明了指令进行的是字节操作。

mov al,1
mov al,bl
mov al,ds:[0]
mov ds:[0],al
inc al
add al,100

二、在没有寄存器名存在的情况下,用操作符 X ptr 指明内存单元的长度,X在汇编指令中可以为word或byte。
例如,下面的指令中,用word ptr指明了指令访问的内存单元是一个字单元。

mov word ptr ds:[0],1
inc word ptr [bx]
inc word ptr ds:[0]
add word ptr [bx],2

下面的指令中,用byte ptr指明了指令访问的内存单元是一个字节单元。

mov byte ptr ds:[0],1
inc byte ptr [bx]
inc byte ptr ds:[0]
add byte ptr [bx],2

再没有寄存器参与的内存单元访问指令中,用word ptr或byte ptr显性地指明所要访问的内存单元的长度是很必要的。否则,CPU无法得知所要访问的单元是字单元,还是字节单元。假设我们用Debug查看内存的结果如下:
2000:1000 FF FF FF FF FF FF ......
那么指令:

mov ax,2000H
mov ds,ax
mov byte ptr [1000H],1

将使内存中的内容变为:
2000:1000 01 FF FF FF FF FF ......
而指令:

mov ax,2000H
mov ds,ax
mov word ptr [1000H],1

将使内存中的内容变为:
2000:1000 01 00 FF FF FF FF ......

这是因为 mov byte ptr [1000H],1 访问的是地址为ds:1000H的字节单元,修改的是ds:1000H单元的内容;而mov word ptr [1000H],1访问的是地址为ds:1000H的字单元,修改的是ds:1000H和ds:10001H两个单元的内容。

三、其他方法
有些指令默认了访问的是字单元还是字节单元,比如,push [1000H] 就不用指明访问的是字单元还是字节单元,因为push指令只进行字操作。

您需要登录后才可以回帖 登录 | register

本版积分规则

雪舞知识库 | 浙ICP备15015590号-1 | 萌ICP备20232229号|浙公网安备33048102000118号 |天天打卡

GMT+8, 2025-1-18 09:51 , Processed in 0.102458 second(s), 7 queries , Redis On.

Powered by XueWu Licensed

Copyright © Tencent Cloud.

快速回复 返回顶部 返回列表