第三章 寄存器(内存访问)

第三章 寄存器(内存访问)

3.1 内存中字的存储

1.一个字要用两个地址连续的内存单元来存放。

2.低位字节存放在低地址单元中,高位字节存放在高地址单元中。

3.字单元:存放一个字型数据(16位)的内存单元由两个地址连续的内存单元组成。高地址内存单元存放字型数据的高位字节,低地址内存单元中存放字型数据的低位字节。

4.将起始地址为N的字单元称为N地址字单元,N号单元存放低位字节,N+1号单元存放高位字节。

image

问题 3.1:

​ 对于图 3.1:

​ (1)0地址单元中存放的字节型数据是多少?

​ (2)0地址字单元中存放的字型数据是多少?

​ (3)2地址单元中存放的字节型数据是多少?

​ (4)2地址字单元中存放的字型数据是多少?

​ (5)1地址字单元中存放的字型数据是多少?

解析:

(1)0地址单元中存放的字节型数据:20H;

(2)0地址字单元中存放的字型数据:4E20H;

(3)2地址单元中存放的字节型数据:12H;

(4)2地址字单元中存放的字型数据:0012H;

(5)1地址字单元,即起始地址为1的字单元,它由1号单元和2号单元组成,用这两个单元存储一个字型数据,高位放在2号单元中,即:12H,低位放在1号单元中,即:4EH,它们组成字型数据是124EH,大小为:4686。

任何两个地址连续的内存单元,N号单元和N+1号单元,可以将它们看成两个内存单元,也可看成一个地址为的字单元中的高位字节单元和低位字节单元。

3.2 DS 和[address]

DS寄存器:通常用来存放要访问数据的段地址

[address]表示一个偏移地址为address的内存单元,段地址默认放在ds中

通过数据段段地址和偏移地址即可定位内存单元。

比如我们要读取10000H单元的内容,可以用如下的程序段进行。

image

"[…]“表示一个内存单元,”[…]"中的数字表示内存单元的偏移地址

指令执行时,8086CPU自动取ds中的数据为内存单元的段地址

由于8086CPU硬件设计问题,不支持将数据直接送入段寄存器

**问题 3.2:**写几条指令,将al中的数据送入内存单元10000H中。

答案:

mov bx, 1000H
mov ds, bx
mov [0], al

解析:将数据从内存单元送到寄存器的格式是:“mov寄存器名内存单元地址”,从寄存器到内存单元则是:“mov内存单元地址,寄存器名”。10000H可表示为 1000:0,用 ds 存放段地址1000H,偏移地址是0,则mov [0],al可完成从al到10000H的数据传送。

3.3 字的传送

8086CPU是16位结构,有16根数据线,所以可以一次性传送16位的数据,即一次可以传送一个字。

只要在mov指令中给出16位的寄存器就可以进行16位数据的传送了,例如:

image

在内存和寄存器之间传送字型数据时,高地址单元和高8位寄存器、低地址单元和低8位寄存器相对应。

**问题3.3:**内存情况如下,写出下面的指令执行后寄存器ax,bx,cx中的值。

image image

答案&解析:

image

**问题3.4:**内存中的情况如下,写出下面的指令执行后内存中的值。

image image

答案&解析:

image

3.4 mov、add、sub指令

mov指令有以下几种形式:

image

add指令也有以下几种形式:

image

同样的,sub指令亦有以下几种形式:

image

3.5 数据段

我们可以根据需要,将一组长度小于64KB、地址连续、起始地址为16的倍数的内存单元定义为一个数据段,用来作为专门存放数据的内存空间。

问题 3.5:写几条指令,与累加数据段中的前3个字型数据。

答案&解析:

image

3.6 栈

栈是一种具有特殊的访问方式的存储空间

下面我们通过一个例子来了解一下栈的结构:

image

如上图,其实所谓的栈就像一个一端开口的桶,这个桶一次只允许放一个东西或者拿一个东西,很显然,我们最先放进去的东西不能最先的拿出来,就拿上图来说,我们想要拿出高等数学,就必须得先拿出软件工程和C语言,因此,我们可以理解为,先进去的东西在最底端,而后进去的则在最顶端,这是一个很不正式的描述,我们理解栈的结构即可。

栈的基本操作有:

(1)入栈:将一个新的元素放到栈顶;

(2)出栈:从栈顶取出一个元素。

栈的操作规则:后进先出

3.7 CPU 提供的栈机制

其实在今天,现在的CPU都已经有了栈的设计。

在基于8086CPU编程的时候,可以将一段内存当作栈来使用

8086CPU提供入栈和出栈指令,最基本的是push和pop

push ax // 表示将寄存器ax的数据送入栈中
pop ax // 表示从栈顶取出数据送入ax

8086CPU的入栈和出栈操作都是以字为单位进行的。

字型数据用两个单元存放,高地址单元存放高8位,低地址单元存放低8位

push ax表示将寄存器ax中的数据送入栈中,由两步完成。

  1. SP=SP-2,SS:SP指向当前栈顶前面的单元,以当前栈顶前面的单元为新的栈顶;
  2. 将ax中的内容送入SS:SP指向的内存单元处,SS:SP此时指向新栈顶。

image

pop ax表示从栈顶取出数据送入ax,由以下两步完成。

  1. 将SS:SP指向的内存单元处的数据送入ax中;
  2. SP=SP+2,SS:SP指向当前栈顶下面的单元,以当前栈顶下面的单元为新的栈顶。

image

3.8 栈顶超界的问题

以下两种情况会发生栈顶超界

(1)当栈满的时候,再使用push指令入栈;

image

(2)当栈空的时候,再使用pop指令出栈。

image

栈顶超界的后果:栈顶超界是危险的,可能损坏在栈空间之外的空间中存放的数据、代码等,并引发错误。

3.9 push、pop 指令

push和pop指令时能够在寄存器和内存之间传送数据的

栈与内存:栈空间当然也是内存空间的一部分,他只是一段可以以一种特殊的方式进行访问的内存空间

push 寄存器:将寄存器中的数据放入栈中
push 段寄存器:将一个段寄存器中的数据入栈
push 内存单元:将一个内存单元处的字入栈(栈的操作都是以字为单位)
pop  寄存器:将栈中的数据放入寄存其中
pop  段寄存器:出栈,用一个段寄存器接受出栈的数据 
pop  内存空间:出栈,用一个内存字单元接受出栈的数据 pop[2]

push、pop实质上就是一种内存传送指令,可以在寄存器和内存之间传送数据,与mov指令不同的是,push和 pop 指令访问的内存单元的地址不是在指令中给出的,而是由SS:SP指出的。同时,push和 pop指令还要改变SP中的内容。

问题 3.7:编程,将10000H~1000FH这段空间当作栈,初始状态栈是空的,将AX、BX、DS中的数据入栈。

答案&解析:

image

3.10 栈段

对于8086PC机,在编程时,可以根据需要,将一组内存单元定义为一个段。

我们可以将长度为N(N≤64KB)一组地址连续、起始地址为16的倍数的内存单元,当作栈空间来用,从而定义了一个栈段。

比如,我们将10010H~1001FH 这段长度为16字节的内存空间当作栈来用,以栈的方式进行访问。这段空间就可以称为一个栈段,段地址为1001H,大小为16字节。

将一段内存当作栈段,仅仅是我们在编程时的一种安排,CPU不会这样安排。
C机,在编程时,可以根据需要,将一组内存单元定义为一个段。

我们可以将长度为N(N≤64KB)一组地址连续、起始地址为16的倍数的内存单元,当作栈空间来用,从而定义了一个栈段。

比如,我们将10010H~1001FH 这段长度为16字节的内存空间当作栈来用,以栈的方式进行访问。这段空间就可以称为一个栈段,段地址为1001H,大小为16字节。

将一段内存当作栈段,仅仅是我们在编程时的一种安排,CPU不会这样安排。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值