文档详情

【精选】8086汇编语言循环程序设计.ppt

发布:2018-04-22约6.37千字共27页下载文档
文本预览下载声明
5.6.3 循环程序设计 循环程序结构就是重复执行某一段程序,直到某个条件出现为止。循环程序结构同分支程序结构有相似之处,都是根据条件来实现的,只不过循环是一种运动方向总是向后的分支程序结构。因此,循环可以用分支来实现。IP值受计数器CX中的值不为0而循环影响标志的指令DEC。 1.循环程序的组成 一个循环程序通常由四部分构成: ⑴ 初始化部分 建立循环初始值。如初始化地址指针,计数器,其他循环参数的起始值等。 ⑵ 工作部分 它是循环程序的这主要部分,是为完成某种特定功能而设计的程序段。 ⑶ 修改部分 为保证正确的循环而修改某些参数。如修改计数器的值、操作数地址等。 ⑷ 控制部分 判断循环结束条件是否成立。这是循环程序设计的关键。通常判断循环是否结束的办法有两种: ① 用计数控制循环:循环是否已进行预定次数,它适用于已知循环次数的循环程序设计; ② 用条件控制循环:循环终止条件是否已成立,它适用于未知循环次数的循环程序设计。 2.循环控制方法 ⑴ 用计数控制循环 [例3] 在xx单元开始的连续单元中存放有10个无符号数,从中找出中最大者送yy单元。 根据题意,我们把第一个数先送入AL寄存器中,然后将AL中的数与后面的9个数逐个进行比较。如果AL中的数较小,则两数交换;如果AL中的数大,则不交换。在比较过程中,AL中始终保持较大的数,这样,比较9次后,则最大的数在AL中,最后把AL中的数(最大者)存入yy单元。 由此可画出程序的流程图: 从一批数中求最大者流程图 程序编写如下: DATA SEGMENT xx DB 49,38,65,12,97,13,55,27,28,85 yy DB ? DATA ENDS CODE SEGMENT ASSUME CS:CODE, DS:DATA START: MOV AX, DATA MOV DS, AX LEA BX, xx MOV AL, [BX] MOV CX, 9 LOOP1: INC BX CMP AL, [BX] JAE LOOP2 XCHG AL, [BX] LOOP2: DEC CX JNZ LOOP1 MOV yy, AL MOV AH, 4CH INT 21H CODE ENDS END START (2)用条件控制循环 有些情况无法确定循环次数,但是循环何时结束,可用某种条件来确定。这时,编制程序主要是寻找控制条件及对控制条件的检测。 [例5] 从自然数1开始累加,直到累加和大于1000为止,统计被累加的自然数的个数,并把统计的个数送入n单元,把累加和送入sum单元。 根据题意,被累加的自然数的个数事先是未知的,也就是说,循环的次数是未知的,因此不能用计数器方法控制循环。但题目中给定一个重要条件,即累加和大于1000则停止累加,因此,可以根据这一条件控制循环。我们用CX寄存器统计自然数的个数,用AX寄存器存放累加和,用BX寄存器存放每次取得的自然数。 程序的流程图如下所示。 程序编写如下: DATAS SEGMENT n DW ? sum DW ? DATAS ENDS STACK SEGMENT PARA STACK ’stack’ DW DUP(?) STACK ENDS CODES SEGMENT MAIN PROC FAR ASSUME CX:CODES, DS:DATAS, SS:STACK START: PUSH DS MOV AX, 0 PUSH AX MOV AX, DATAS MOV DS, AX MOV CX, 0 MOV AX, 0 MOV BX, 0 LOOPT: INC BX ADD AX, BX INC CX CMP AX, 1000 JLE LOOPT MOV n, CX MOV sum, AX RET MAIN ENDP CODES ENDS END STA
显示全部
相似文档