汇编语言--------王爽第8章

数据处理的两个基本问题

  • bx、si、di和bp
  • 机器指令处理的数据在什么地方
  • 立即数
  • 寄存器
  • 段地址(SA)和偏移地址(EA)
  • 寻址方式
  • 指令要处理的数据有多长
  • div指令
  • 伪指令dd
  • dup

本章是对前面的所有内容是具有总结性的,我们知道计算机是进行数据处理的、运算的机器,那么有两个基本的问题就包含其中:

  1. 处理的数据在什么地方?
  2. 要处理的数据有多长。

bx、si、di和bp

  1. 在8086CPU中,只有这4个寄存器可以用在‘[…]’中来进行内存单元的寻址。
  2. 在[…]中,这4个寄存器只能单独出现,或者只能两两组合出现,不能bx和bp同时出现。
  3. 只要在[…]中使用寄存器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。所以需要在机器指令中指明,指令进行的是字操作还是字节操作。有以下两种方式指明要处理的数据尺寸是什么。

  1. 通过寄存器名指明要处理的数据尺寸
    比如mov ax,1这指明要处理的数据是以字为单位的数据。
  2. 在没有寄存器名存在的情况下,用的操作符X ptr指明内存单元的长度,X在汇编指令中可以为word或byte。
    比如 mov word ptr ds:[0],1这条指令指明要操作的数据长度为1个字
  3. 其他方法
    有些方法默认了访问的是子单元还是字节单元,比如,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(重复的双字型数据)

你可能感兴趣的:(汇编语言--------王爽第8章)