1 / 28
文档名称:

循环子程序.ppt

格式:ppt   页数:28
下载后只包含 1 个 PPT 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

循环子程序.ppt

上传人:rjmy2261 2016/1/4 文件大小:0 KB

下载得到文件列表

循环子程序.ppt

相关文档

文档介绍

文档介绍:循环程序设计循环程序结构就是重复执行某一段程序,直到某个条件出现为止。循环程序结构同分支程序结构有相似之处,都是根据条件来实现的,只不过循环是一种运动方向总是向后的分支程序结构。因此,循环可以用分支来实现。:⑴初始化部分建立循环初始值。如初始化地址指针,计数器,其他循环参数的起始值等。⑵工作部分它是循环程序的这主要部分,是为完成某种特定功能而设计的程序段。⑶修改部分为保证正确的循环而修改某些参数。如修改计数器的值、操作数地址等。⑷控制部分第5章汇编语言程序设计判断循环结束条件是否成立。这是循环程序设计的关键。通常判断循环是否结束的办法有两种:①用计数控制循环:循环是否已进行预定次数,它适用于已知循环次数的循环程序设计;②用条件控制循环:循环终止条件是否已成立,它适用于未知循环次数的循环程序设计。⑴用计数控制循环第5章汇编语言程序设计[例3] 在xx单元开始的连续单元中存放有10个无符号数,从中找出中最大者送yy单元。根据题意,我们把第一个数先送入AL寄存器中,然后将AL中的数与后面的9个数逐个进行比较。如果AL中的数较小,则两数交换;如果AL中的数大,则不交换。在比较过程中,AL中始终保持较大的数,这样,比较9次后,则最大的数在AL中,最后把AL中的数(最大者)存入yy单元。由此可画出程序的流程图:第5章汇编语言程序设计从一批数中求最大者流程图开始开始 AL←xx,BX←xx的有效地址,CX←9 AL←xx,BX←xx的有效地址,CX←9 BX←BX+1 BX←BX+1 AL≥[BX]?AL≥[BX]? AL,[BX]中的数交换 AL,[BX]中的数交换 CX←CX-1 CX←CX-1 CX=0?CX=0? yy←AL yy←AL 结束结束YYYYNNNN第5章汇编语言程序设计程序编写如下:DATASEGMENTxxDB 49,38,65,12,97,13,55,27,28,85yyDB ?DATAENDSCODESEGMENTASSUME CS:CODE, DS:DATASTART:MOV AX, DATAMOV DS, AXLEA BX, xxMOV AL, [BX]MOV CX, 9第5章汇编语言程序设计LOOP1:INC BX CMP AL, [BX]JAE LOOP2XCHG AL, [BX]LOOP2:DEC CXJNZ LOOP1MOV yy, ALMOV AH, 4CHINT 21HCODEENDSEND START第5章汇编语言程序设计LOOP1:INC BX CMP AL, [BX]JAE LOOP2XCHG AL, [BX]LOOP2:DEC CXJNZLOOP1MOV yy, ALAAMMOV DL, AHOR DL, 30HMOV AH, 2INT 21HMOV DL, ALOR DL, 30HMOV AH, 2INT 21HMOV AH, 4CHINT 21HCODEENDSEND START第5章汇编语言程序设计(2)用条件控制循环有些情况无法确定循环次数,但是循环何时结束,可用某种条件来确定。这时,编制程序主要是寻找控制条件及对控制条件的检测。[例5] 从自然数1开始累加,直到累加和大于1000为止,统计被累加的自然数的个数,并把统计的个数送入n单元,把累加和送入sum单元。根据题意,被累加的自然数的个数事先是未知的,也就是说,循环的次数是未知的,因此不能用计数器方法控制循环。但题目中给定一个重要条件,即累加和大于1000则停止累加,因此,可以根据这一条件控制循环。我们用CX寄存器统计自然数的个数,用AX寄存器存放累加和,用BX寄存器存放每次取得的自然数。第5章汇编语言程序设计程序的流程图如下所示。开始开始初始化 AX←0, CX←0, BX←0 初始化 AX←0, CX←0, BX←0 BX←BX+1BX←BX+1 AX←AX+BX, CX←CX+1 AX←AX+BX, CX←CX+1 AX≤1000?AX≤1000? n←CX, sum←AX n←CX, sum←AX 结束结束YYNN