第8章

store11h

store11h

110

110

时通信只能限制在你的声音能达到没有扩音器可用或是你的眼睛能看到也许得用望远

时通信只能限制在你的声音能达到没有扩音器可用或是你的眼睛能看到也许得用望远

要回到先前的程序,并使用a、b、cນ中原有的值。

当然,你能做的工作只是简单地把寄存器aທ、bຘ、c中的值保存到存储器中的不同位置,

以后再把这些位置的值装载到เ寄存器中,但这样做需要保存值被保存的位置。一个显然的方

法是把寄存器压入堆栈:

pusha

pushb

pushcນ

一会儿再解释这些指令的作用。现在,我们只需要知道它们以某种方แ式把寄存器的内容

保存在一个ฐ后进先出的存储器中。一旦这些语句执行了,你的程序就可以毫无顾虑地利用这

些寄存器来做其他工作。为了得到原来的值,只需简单地按与压入堆栈相反的顺序把它们从

堆栈中弹出即可,如下所示:

198๖编码的奥秘

下载

popc

popb

popa

记住是后进先出。如果用错了pop语句的顺序,就会引起错误。

堆栈机制的一个好处在于一个程序的不同部分都可以使用堆栈而不会出现问题。例如,

在把aທ、bຘ、c压入堆栈中后,程序的其他部分还可能ม需要把寄存器c、d、e的内容压入堆栈:

pushc

pushd

pushe

接着,这一部ຖ分程序所要做的就是在第一部分弹出cນ、b和aທ之前,用下述方法恢复寄存

器的值:

pope

popd

popc

堆栈是怎样实现的呢?先,堆栈只是不被别的东西使用的正常的ram的一部分。8๖080

微处理器包含一个特殊的16位寄存器来对这一部分存储器进行寻址,这个16位寄存器叫作堆

栈指针。

这里举的压入和弹出寄存器的例子对于808๖0来说不太准确。80่80的push指令实际上是存

储16位的值到เ堆栈,pop指令用来恢复它们。因此8080不用像pushc和popc这样的指令,

它有下述8๖条指令:

操作码指令操作码指令

c9

d5pushded1้popde

e5pushhle1pophl

f5pushp9f1popp9

pushbc指令把寄存器b和cນ的内容保存到堆栈中ณ,popbc指令恢复它们。最后一行的

缩写ps9指的是程序状态字,前面讲过,它是包含有标志位的8位寄存器。最后一行的两条指

令实际上是把累加器和ps9都压入和弹出堆栈。如果你想保存所有寄存器和标志位的内容,

可以使用:

pushp9๗

pushbcນ

pushde

pushhl

当以后想恢复这些寄存器的内容时,按相反的顺序使用pop指令:

pophl

popde

popbc

popp9

堆栈是怎样工作的呢?假设堆栈指针为8๖000h,pushbc指令将引起下面这些情况生: