引言:
本章对前面的所有nei'内容是具有总结性的。我们知道,计算机时进行数据处理、运算的机器,那么有两个基本的问题就包含在其中:
(1)处理的数据在什么地方?
(2)要处理的数据有多长?
这两个问题,在机器指令中必须给以明确或隐含的说明,否则计算机就无法工作。
本章的学习将针对8086CPU对这两个基本问题进行讨论。虽然讨论是在8086CPU的基础上进行的,但是这两个基本问题确实普遍的,对任何一个处理器都存在的。
在以后的学习中,我们将使用两个描述性符号reg(寄存器的缩写)来表示一个寄存器,用sreg(段寄存器的缩写)表示一个段寄存器。
reg的集合包括:ax、bx、cx、dx、ah、al、bh、bl、ch、cl、dh、dl、sp、bp、si、di;
sreg的集合包括:ds、ss、cs、es。
8.1 bx、si、di、bp
前面三个寄存器已经有过接触,总结一下:
(1)在8086CPU中,只有这4个寄存器(bx、bp、si、di)可以用在“[……]”中来进行内存单元的寻址。
正确的指令: 错误的指令:
mov ax,[bx] mov ax,[cx]
mov ax,[bx+si] mov ax,[ax]
mov ax,[bx+di] mov ax,[dx]
mov ax,[bp] mov ax,[ds]
mov ax,[bp+si] mov ax,[bx+ax]
mov ax,[bp+di]
(2)在“[……]”中,这四个寄存器(bx、bp、si、di)可以单个出现,或只能以四种组合出现:
bx和si、bx和di、bp和si、bp和di。
错误的用法:
mov ax,[bx+bp]
mov ax,[si+di]
正确的用法:
mov ax,[bx] mov ax,[bp+si]
mov ax,[si] mov ax,[bp+di]
mov ax,[di] mov ax,[bx+si+idata]
mov ax,[bp] mov ax,[bx+di+idata]
mov ax,[bx+si] mov ax,[bp+si+idata]
mov ax,[bx+di] mov ax,[bp+di+idata]
(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)
8.2机器指令处理的数据所在位置
绝大部分机器指令都是进行数据处理的指令,处理大致可分为三类:
读取、写入、运算
在机器指令这一层来讲,并不关心数据的值是多少,而关心指令执行前一刻,他将要处理的数据所在的位置。
指令在执行前,所要处理的数据