本章是对前面的所有内容是具有总结性的,我们知道计算机是进行数据处理的、运算的机器,那么有两个基本的问题就包含其中:
- 处理的数据在什么地方?
- 要处理的数据有多长。
bx、si、di和bp
- 在8086CPU中,只有这4个寄存器可以用在‘[…]’中来进行内存单元的寻址。
- 在[…]中,这4个寄存器只能单独出现,或者只能两两组合出现,不能bx和bp同时出现。
- 只要在[…]中使用寄存器bp,而指令中没有显性地给出段地址,段地址就默认在ss中。
机器指令处理的数据在什么地方
机器指令处理的数据可以在3个地方:CPU 内部、内存、端口比如下表所列的指令。
机器码 | 汇编指令 | 指令执行前数据的位置 |
---|---|---|
8E1E000 | mov bx,[0], | 内存,ds:0单元 |
89C3 | mov bx,ax | CPU内部,ax寄存器 |
BB0100 | mov bx,1 | CPU内部,指令缓冲器 |
立即数
对于直接包含在机器指令中的数据(执行前就在CPU的指令缓冲器中),在汇编语言中称为:立即数,在汇编语言中直接给出。
寄存器
指令要处理的数据在寄存器中,在汇编指令中给出相应的寄存器名、
段地址(SA)和偏移地址(EA)
指令要处理的数据在内存中,在汇编指令可以用[X]的格式给出EA,SA在某个段寄存器中,或者可以显式给出SA:EA来指定内存单元。
寻址方式
寻址方式的总结如下表:
例子 | 名称 |
---|---|
[idata] | 直接寻址 |
[bx] | 寄存器间接寻址 |
[bx+idata] | 寄存器相对寻址 |
[bx+si] | 基址变址寻址 |
[bx+si+idata] | 相对基址变址寻址 |
指令要处理的数据有多长
8086CPU的指令可以处理两种尺寸的数据byte和word。所以需要在机器指令中指明,指令进行的是字操作还是字节操作。有以下两种方式指明要处理的数据尺寸是什么。
- 通过寄存器名指明要处理的数据尺寸
比如mov ax,1这指明要处理的数据是以字为单位的数据。 - 在没有寄存器名存在的情况下,用的操作符X ptr指明内存单元的长度,X在汇编指令中可以为word或byte。
比如 mov word ptr ds:[0],1这条指令指明要操作的数据长度为1个字 - 其他方法
有些方法默认了访问的是子单元还是字节单元,比如,push [1000H]就不用指明访问的是字单元还是字节单元,因为push指令只进行字操作。
div指令
div是除法指令,使用div做除法的时候应该注意以下问题。
(1)除数:有8位和16位两种,在一个reg或内存单元中
(2) 被除数:默认放在AX或DX和AX中。如果除数为8位,则被除数为16位放在AX中。如果除数为16位,则被除数为32位高116位放在dx中,低16位放在ax中。
(3)如果除数为8位,则除法的商放在AL中,余数放在AH中。如果除数为16位,则除法的商放在AX中,DX存储除法的余数。
伪指令dd
前面我们用db和dw定义字节型数据和字型数据。dd是用来定义dword(double word)双字型数据的。
data segment
dd 2
data ends
上面这段指令定义了一个双字型数据。第三个数据为00000002在data:0处占2个字。
dup
dup是一个操作符,在汇编语言同db、dw、dd一样。它是和db、dw、dd等数据定义伪指令配合使用的,用来进行数据的重复。
比如
db 3 dup(0)这个指令的意义是在内存中定义了3个字节型数据内容为0。相当于db 0,0,0
可见dup的使用格式如下:
db 重复的次数 dup (重复的字节型数据)
dw 重复的次数 dup (重复的字型数据)
dd 重复的次数 dup(重复的双字型数据)