![]() | 第5章 子程序和串处理 | -97- | |||||||||||||||||||
指针,"DISP"过程取得指针后首先判断此指针是否指向字符串的最后一个字符,若不是则将指针加一后压入堆栈并调用其自身。反复几次后堆栈中将形成如图5-3所示的一系列数据组。 我们把一次调用在堆栈中保存的数据称为一帧。当指针最终指向最后一个字符时,DISP将按第一种情况处理--执行"#1部分"程序显示最后这个字符。这部分程序结束时的RET指令使CPU返回至"#2部分"继续执行程序。这部分程序负责由堆栈中取回指针并将其减1,使其指向前一个字符,然后将这个字符显示出来。这一段程序结束时的RET指令仍然使CPU返回至"RETN_ADDR"处,直至堆栈中所有数据帧处理完毕后DISP才真正返回到主过程。 |
|||||||||||||||||||||
![]() 图5-3 递归调用的堆栈结构 |
|||||||||||||||||||||
5.3 数据串处理 | |||||||||||||||||||||
什么是"串"?一般来说在内存中连续存放的一系列位宽一致的数据就可以称为一个串。最为常见的就是以"$"结尾的一个字符串。8086/88和与其完全兼容的CPU有几个专门的寄存器和一些指令用于处理数据串,这些专门的指令就是所谓的"串指令"。这些寄存器和指令就是这一节主要讨论的内容。这一节将结束对8086/88内部寄存器的讨论(标志寄存器除外),在后面的学习中这些知识有助于设计出更灵活的程序。 由于字符串比较常用,而且也较为直观,所以后面所举实例基本都以字符串为代表。下面我们就来讨论第一个简单的问题:字符串的输入。 我们在第三章中介绍了单字符的输入方法:调用INT 21H的1号功能。用此功能配合一点 |
|||||||||||||||||||||
Copyright © 2004-2015 Reanimator | www.cookmoon.org |