循环程序设计

来源:本站
导读:目前正在解读《循环程序设计》的相关信息,《循环程序设计》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《循环程序设计》的详细说明。
简介:下面简单的给大家介绍一下循环程序的设计,并且加了点例题让大家来学习。

顺序程序和分支程序中的指令,最多只执行一次。在实际问题中重复地做某些事的情况是很多的,用计算机来做这些事就要重复地执行某些指令。重复地执行某些指令,最好用循环程序实现。

循环程序一般由4部分组成。

(1)置循环初值。即设置循环过程中有关工作单元的初始值,如置循环次数、地址指针及工作单元清零等。

(2)循环体。即循环的工作部分,完成主要的计算或操作任务,是重复执行的程序段。

这部分程序应特别注意,因为它要重复执行许多次,若能少写一条指令,实际上就是少执行某条指令若干次,因此,应注意优化程序。

(3)循环修改。每循环一次,就要修改循环次数、数据及地址指针等。

(4)循环控制。根据循环结束条件,判断是否结束循环。

如果在循环程序的循环体中不再包含循环程序,即为单重循环程序。如果在循环体中还包含有循环程序,那么这种现象就称为循环嵌套,这样的程序就称为二重循环程序或三重以至多重循环程序。在多重循环程序中,只允许外重循环嵌套内重循环程序,而不允许循环体互相交叉,也不允许从循环程序的外部跳入循环程序的内部。

结构是“先执行后判断”,适用于循环次数已知的情况。其特点是一进入循环,先执行循环处理部分,然后根据循环次数判断是否结束循环。

结构是“先判断后执行”,适用于循环次数未知的情况。其特点是将循环控制部分放在循环的入口处,先根据循环控制条件判断是否结束循环,若不结束,则执行循环操作;若结束,则退出循环。

【例4-10】多个单字节数求知。

已知有10个单字节数,依次存放在内部RAM 40H单元开始的数据存储区中,求和并将结果存人寄存器R2、R3中(高位存R2,低位存R3)。

本题中,要重复进行加法运算,因此采用循环结构程序。循环次数就是数据块字节数,这是已知的。在置初值时,将数据块长度置人寄存器R5;将数据块首地址送人寄存器R0,即以R0作为数据块的地址指针,采用间接寻址方式:每做一次加法之后,修改地址指针,以便取出下一个数来相加,并且使计数器R5减l。到R5减为0时,求和结束。

ORG 2000H SUM: MOV R0,#40H ;设地址指针 MOV R5,#0AH ;计数器初值送R5 SUM: MOV A,#00H MOV R2,A LP: ADD A,@R0 JNC LP1 INC R2 ;若有进位,和的高八位+1 LP1: INC R0 ;地址指针+1 DJNZ R5,LP ;判循环结束条件 MOV R3,A ;存和的低八位 END

【例4-11】从内存BLOCK单元开始有一个无符号数的数据块,其长度为LEN,试求出其最大值,并存入MAX单元。

这是一个搜索问题。这里采用依次进行比较和取代的方法来寻找最大值。具体做法是:先取出第一个数作为基准,和第二个数比较,若比较结果基准数大,不作变动;若比较结果基准数小,则用大数来代替原基准数,然后再和下一个数作比较。到比较结束时,基准数就是所求的最大值。

为了进行两数的比较,采用两数相减以后判断CY的值来确定哪个数大,这比用CJNE指令更简单。比较时将基准数放在累加器A中。若A中先放人零,比较次数等于LEN;若A中先放人第一个数,则比较次数等于LEN-1。采用R2作为计数器,R1作为地址指针。

提醒:《循环程序设计》最后刷新时间 2024-03-14 01:00:04,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《循环程序设计》该内容的真实性请自行鉴别。