寄存器

来源:互联网 发布:python 打包发布 编辑:程序博客网 时间:2024/05/21 08:43

mov 寄存器名 内存单元地址(偏移地址,段地址在DS中),[  ]说明操作对象的源地址是一个内存单元,8086CPU自动取ds中的数据作为内存单元的段地址ds中的数据位内存单元的段地址。

  由于8086CPU硬件设计的缘故,它不支持用mov指令将地址数据直接写到段地址寄存器中,只能先写到某个通用寄存器中,然后再写到段地址寄存器中

1.         这里将使用一个描述性的符号“( )”来表示一个寄存器或一个内存单元中的内容。“( )”中的元素可以有3种类型:寄存器名、段寄存器名、内存单元的物理地址(一个20位数据)。如:(ax)、(ds)、(al)、(cx)、(20000H)、((ds)*16 + (bx))都是正确的,(2000:0),((ds):1000H)是错误的

2.         mov ax,[0] 即(ax)=((ds)*16+0)                mov al,[0] 即(al)=((ds)*16+0)

3.         要完整地描述一个内存单元,需要两种信息:

1)        内存单元的地址

2)        内存单元的长度(类型)。

4.         用[0]表示一个内存单元时,0表示单元的偏移地址,段地址默认在ds中,单元的长度(类型)可以由具体指令中的其他操作对象(比如说寄存器)指出。

5.         [bx]同样也表示一个内存单元,它的偏移地址在bx中,如:

1)        mov ax,[bx] 即(ax)=((ds)*16+(bx))

2)        mov al,[bx]  即(al)=((ds)*16+(bx))

6.         “(X)”所表示的数据有两种类型:字节或字。是哪种类型由寄存器名或具体的运算决定。例如:

1)        (al)、(bl)、(cl)等得到的数据为字节型;(ds)、(ax)、(bx)等得到的数据为字型。

2)        (al)=(20000H),则(20000H)得到的数据为字节型;(ax)=(20000H),则(20000H)得到的数据为字型。

7.         约定符号idata表示常量。如:

1)        mov ax ,[idata]就代表mov ax,[1] 、mov ax,[2]、 mov ax,[3]

2)        mov bx ,idata就代表 mov bx,1  、 mov bx,2  、mov bx,3


一、     bx、si、di和bp

1.         在8086CPU中,只有这4个寄存器可以用在“[…..]”中来进行内存单元的寻址。如下的指令都是正确的:

1)        mov ax,[bx]

2)        mov ax,[bx+si]

3)        mov ax,[bx+di]

4)        mov ax,[bp]

5)        mov ax,[bp+si]

6)        mov ax,[bp+di]

而下面的指令是错误的:

1)        mov ax,[cx]

2)        mov ax,[ax]

3)        mov ax,[dx]

4)        mov ax,[ds]

2.         在[…..]中,这4个寄存器可以单个出现,或只能以4种组合出现:bx和si、bx和di、bp和si、bp和di。比如下面的指令是正确的:

1)        mov ax,[bx]

2)        mov ax,[si]

3)        mov ax,[di]

4)        mov ax,[bp]

5)        mov ax,[bx+si]

6)        mov ax,[bx+di]

7)        mov ax,[bp+si]

8)        mov ax,[bp+di]

9)        mov ax,[bx+si+idata]

10)     mov ax,[bx+di+idata]

11)     mov ax,[bp+si+idata]

12)     mov ax,[bp+di+idata]

下面的指令是错误的:

1)        mov ax,[bx+bp]

2)        mov ax,[si+di]

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

1)        mov ax,[bp]                      含义:(ax)=((ss)*16+(bp))

2)        mov ax,[bp+idata]             含义:(ax)=((ss)*16+(bp)+idata)

3)        mov ax,[bp+si]                  含义:(ax)=((ss)*16+(bp)+(si))

4)        mov ax,[bp+si+idata]         含义:(ax)=((ss)*16+(bp)+(si)+idata)   

   机器指令处理的数据在什么地方

1.         绝大部分机器指令都是进行数据处理的指令,处理大致可分为3类:读取、写入、运算。在机器指令这一层来讲,并不关心数据的值的多少,而关心指令执行前的一刻,它将要处理的数据所在的位置。指令在执行前,所要处理的数据可以在3个地方:CPU内部、内存、端口。

1.         在汇编语言中如何表达数据的位置?汇编语言中用3个概念来表达数据的位置

1)        立即数

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

2)        寄存器

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

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

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

 寻址方式

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

             指令要处理的数据有多长

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

1)        通过寄存器名指明要处理的数据的尺寸:mov ax,1     inc al

2)        在没有寄存器名存在的情况下,用操作符X ptr指明内存单元的长度,X在汇编指令中可以为word或byte。add word ptr [bx],2   inc byte ptr ds:[0]

3)        其他方法   有些指令默认了访问的是字单元还是字节单元,如 push  [1000H]



0 0