第8章 数据处理的两个基本问题 其一

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

1)处理的数据在什么地方

2)要处理的数据有多长?

这两个问题,在机器指令中必须给以明确或隐含的说明,否则计算机就无法工作。

为了描述上的简洁,在以后的课程中,我们将使用两个描述性的符号reg来表示一个寄存器,用sreg表示一个段寄存器。

reg的集合包括:ax、bx、cx、dx ah al bh bl ch cl dh dl sp bp si di

sreg 的集合包括:ds  ss   cs  es  

1)在8086cpu中,只有这4个寄存器(bx、bp、si、di)可以用在[...]中来进行内存单元的寻址。

在[...]中,这4个寄存器(bx、bp、si、di)可以单个出现,或只能以四种组合出现:

bx和si、bx和di、bp和si、bp和di

 只要在[...]中使用寄存器bp,而指令中没有显性的给出段地址,段地址就默认在ss中。比如:

绝大部分机器指令都是进行数据处理的指令,处理大致可分为三类:

读取、写入、运算

在机器指令这一层来讲,并不关心数据的值是多少,而关心指令执行前一刻,它将要处理的数据所在的位置。

指令在执行前:所要处理的数据可以在三个地方:

cpu内部、内存、端口

(端口我们将在后面的课程中进行讨论)

 在汇编语言中如何表达数据的位置?

汇编语言中用三个概念来表达数据的位置。

1、立即数(idata)

2、寄存器

3、段地址(SA)和偏移地址(EA)

1、立即数

对于直接包含在机器指令中的数据(执行前在cpu的指令缓冲器中),在汇编语言中称为:立即数(idata),在汇编指令中直接给出。例如:

mov ax,1

add bx,2000h

or bx,00010000b

mov al,'a'

2、寄存器

指令要处理的数据在寄存器中,在汇编指令中给出相应的寄存器名。

例如:

mov ax,bx

3、段地址(SA)和偏移地址(EA)

指令要处理的数据在内存中,在汇编指令中可用[x]的格式给出EA,SA在某个段寄存器中。

存放段地址的寄存器可以是默认的

存放段地址的寄存器也可以是显性的给出。

8.4  寻址方式

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

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

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

下面的指令中,用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 da:[0],1

inc byte ptr [bx]

inc byte ptr ds:[0]

add byte ptr [bx],2

在没有寄存器参与的内存单元访问的指令中,用word  ptr或byte  ptr显性地指明所要访问地内存单元地长度是很必要地。

否则,cpu无法得知所要访问地单元是字单元,还是字节单元。

另外,有些指令默认了访问地是字单元还是字节单元,

比如:

push  [1000H]就不用指明访问的是字单元还是字节单元,因为push指令只进行字操作。

原文地址:https://www.cnblogs.com/fate-/p/12922057.html