【汇编语言】数据处理的两个基本问题 —— 汇编语言中的数据奥秘:数据位置与寻址方式总结-LMLPHP

前言

1. 引言

1.1 两个基本问题

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

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

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

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

本章中,我们就要针对8086CPU对这两个基本问题进行讨论。虽然讨论是在8086CPU的基础上进行的,但是这两个基本问题却是普遍的,对任何一个处理器都存在。

1.2 两个描述性符号

我们定义的描述性符号:reg 和 sreg

为了描述上的简洁,在以后的内容中,我们将使用这两个描述性的符号

(1)reg来表示一个寄存器

(2)sreg表示一个段寄存器

2. bx、si、di和bp

bx、si、di和bp,前3个寄存器我们已经用过了,现在我们进行一下总结。

2.1 通过"[…]"来寻址,只有这四种寄存器

如下面的指令都是正确的:

mov ax,[bx]
mov ax,[bx+si]
mov ax,[bx+di]
mov ax,[bp]
mov ax,[bp+si]
mov ax,[bp+di]

而下面的指令是错误的:

mov ax,[cx]
mov ax,[ax]
mov ax,[dx]
mov ax,[ds]

2.2 四种寄存器寻址时的组合方式

比如下面的指令是正确的:

mov ax,[bx]
mov ax,[si]
mov ax,[di]
mov ax,[bp]
mov ax,[bx+si]
mov ax,[bx+di]
mov ax,[bp+si]
mov ax,[bp+di]
mov ax,[bx+si+idata]
mov ax,[bx+di+idata]
mov ax,[bp+si+idata]
mov ax,[bp+di+idata]

下面的指令是错误的:

mov ax,[bx+bp]
mov ax,[si+di]

2.3 使用bp时,默认段地址为ss

比如下面的指令:

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

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

绝大部分机器指令都是进行数据处理的指令,处理大致可分为三类:读取、写入、运算

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

指令在执行前,所要处理的数据可以在三个地方:(端口我们将在后面的内容中进行讨论)。

比如下表中所列的指令。

4. 汇编语言中数据位置的表达

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

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

  1. 立即数(idata)

  2. 寄存器

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

4.1 立即数(idata)

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

例如:

mov ax,1
add bx,2000h
or  bx,00010000b
mov al,'a'

4.2 寄存器

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

例如:

mov ax,bx
mov ds,ax
push bx
mov ds:[0],bx
push ds
mov ss,ax
mov sP,ax

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

指令要处理的数据在内存中,在汇编指令中可用[X]的格式给出EA,SA在某个段寄存器中。(SA,EA是段地址和偏移地址的英文缩写)

(1)存放段地址的寄存器可以是默认的,比如,下面等指令,段地址默认在ds中:

mov ax,[0]
mov ax,[bx]
mov ax,[bx+8]
mov ax,[bx+si]
mov ax,[bx+si+8]

(2)比如,下面等指令,段地址默认在ss

mov ax,[bp]
mov ax,[bp+8]
mov ax,[bp+si]
mov ax,[bp+si+8]

(3)显性的给出存放段地址的寄存器,示例如下:

mov ax,ds:[bp]          含义:(ax)=((ds)*16+(bp))
mov ax,es:[bx]          含义:(ax)=((es)*16+(bx))
mov ax,ss:[bx+si]       含义:(ax)=((ss)*16+(bx)+(si))
mov ax,cs:[bx+si+8]     含义:(ax)=((cs)*16+(bx)+(si)+8)

5. 寻址方式

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

【汇编语言】数据处理的两个基本问题 —— 汇编语言中的数据奥秘:数据位置与寻址方式总结-LMLPHP

结语

今天的分享到这里就结束啦!如果觉得文章还不错的话,可以三连支持一下。

也可以点点关注,避免以后找不到我哦!

Crossoads主页还有很多有趣的文章,欢迎小伙伴们前去点评,您的支持就是作者前进的动力!

【汇编语言】数据处理的两个基本问题 —— 汇编语言中的数据奥秘:数据位置与寻址方式总结-LMLPHP

11-18 06:43