汇编语言循环程序设计课件.ppt

汇编语言循环程序设计课件.ppt

ID:57065529

大小:493.50 KB

页数:27页

时间:2020-07-30

汇编语言循环程序设计课件.ppt_第1页
汇编语言循环程序设计课件.ppt_第2页
汇编语言循环程序设计课件.ppt_第3页
汇编语言循环程序设计课件.ppt_第4页
汇编语言循环程序设计课件.ppt_第5页
资源描述:

《汇编语言循环程序设计课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、5.6.3循环程序设计循环程序结构就是重复执行某一段程序,直到某个条件出现为止。循环程序结构同分支程序结构有相似之处,都是根据条件来实现的,只不过循环是一种运动方向总是向后的分支程序结构。因此,循环可以用分支来实现。IP值受计数器CX中的值不为0而循环影响标志的指令DEC。循环初始状态循环控制条件循环体循环初始状态循环初始状态循环控制条件YYNN1.循环程序的组成一个循环程序通常由四部分构成:⑴初始化部分建立循环初始值。如初始化地址指针,计数器,其他循环参数的起始值等。⑵工作部分它是循环程序的这主要部分,是为完成某

2、种特定功能而设计的程序段。⑶修改部分为保证正确的循环而修改某些参数。如修改计数器的值、操作数地址等。⑷控制部分判断循环结束条件是否成立。这是循环程序设计的关键。通常判断循环是否结束的办法有两种:①用计数控制循环:循环是否已进行预定次数,它适用于已知循环次数的循环程序设计;②用条件控制循环:循环终止条件是否已成立,它适用于未知循环次数的循环程序设计。2.循环控制方法⑴用计数控制循环[例3]在xx单元开始的连续单元中存放有10个无符号数,从中找出中最大者送yy单元。根据题意,我们把第一个数先送入AL寄存器中,然后将AL

3、中的数与后面的9个数逐个进行比较。如果AL中的数较小,则两数交换;如果AL中的数大,则不交换。在比较过程中,AL中始终保持较大的数,这样,比较9次后,则最大的数在AL中,最后把AL中的数(最大者)存入yy单元。由此可画出程序的流程图:从一批数中求最大者流程图开始AL←xx,BX←xx的有效地址,CX←9BX←BX+1AL≥[BX]?AL,[BX]中的数交换CX←CX-1CX=0?yy←AL结束YYNN程序编写如下:DATASEGMENTxxDB49,38,65,12,97,13,55,27,28,85yyDB?DA

4、TAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART:MOVAX,DATAMOVDS,AXLEABX,xxMOVAL,[BX]MOVCX,9LOOP1:INCBXCMPAL,[BX]JAELOOP2XCHGAL,[BX]LOOP2:DECCXJNZLOOP1MOVyy,ALMOVAH,4CHINT21HCODEENDSENDSTART(2)用条件控制循环有些情况无法确定循环次数,但是循环何时结束,可用某种条件来确定。这时,编制程序主要是寻找控制条件及对控制条件的检测。[例5]从自然

5、数1开始累加,直到累加和大于1000为止,统计被累加的自然数的个数,并把统计的个数送入n单元,把累加和送入sum单元。根据题意,被累加的自然数的个数事先是未知的,也就是说,循环的次数是未知的,因此不能用计数器方法控制循环。但题目中给定一个重要条件,即累加和大于1000则停止累加,因此,可以根据这一条件控制循环。我们用CX寄存器统计自然数的个数,用AX寄存器存放累加和,用BX寄存器存放每次取得的自然数。程序的流程图如下所示。开始初始化AX←0,CX←0,BX←0BX←BX+1AX←AX+BX,CX←CX+1AX≤10

6、00?n←CX,sum←AX结束YN程序编写如下:DATASSEGMENTnDW?sumDW?DATASENDSSTACKSEGMENTPARASTACK’stack’DWDUP(?)STACKENDSCODESSEGMENTMAINPROCFARASSUMECX:CODES,DS:DATAS,SS:STACKSTART:PUSHDSMOVAX,0PUSHAXMOVAX,DATASMOVDS,AXMOVCX,0MOVAX,0MOVBX,0LOOPT:INCBXADDAX,BXINCCXCMPAX,1000JLELO

7、OPTMOVn,CXMOVsum,AXRETMAINENDPCODESENDSENDSTART3.多重循环程序设计多重循环又称循环嵌套,即循环套循环。有些问题比较复杂,单重循环难以解决,必须使用多重循环。在使用多重循环时,必须注意以下几点:⑴内循环必须完整地包含在外循环内,内外循环不能相互交叉。⑵内循环既可以嵌套在外循环中,也可以几个内循环并列存在。可以从内循环中直接跳到外循环,但不能从外循环直接跳进内循环中。⑶防止出现“死循环”。无论是外循环,还是内循环,千万不要使循环返回到初始部分,这一点应当特别注意。⑷每次通

8、过外循环再次进入内循环时,初始条件必须重新设置。[例6]利用逐次求大数的方法对内存单元ARRAY开始的一字节为单位的无符号数进行从大到小排序。根据题意,排序方法为:编制程序如下:4938651297135527788549496565979738384949656578788585786555493827131212ARRAYALDATASEGMENTARR

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。