汇编语言循环程序设计PPT课件下载推荐.ppt
- 文档编号:15038569
- 上传时间:2022-10-27
- 格式:PPT
- 页数:27
- 大小:838KB
汇编语言循环程序设计PPT课件下载推荐.ppt
《汇编语言循环程序设计PPT课件下载推荐.ppt》由会员分享,可在线阅读,更多相关《汇编语言循环程序设计PPT课件下载推荐.ppt(27页珍藏版)》请在冰豆网上搜索。
修改部分修改部分为保证正确的循环而修改某些参数。
如修改计数为保证正确的循环而修改某些参数。
如修改计数器的值、操作数地址等。
器的值、操作数地址等。
控制部分控制部分第5章汇编语言程序设计判断循环结束条件是否成立。
这是循环程序设计判断循环结束条件是否成立。
这是循环程序设计的关键。
通常判断循环是否结束的办法有两种:
的关键。
用计数控制循环:
循环是否已进行预定次数,用计数控制循环:
循环是否已进行预定次数,它适用于已知循环次数的循环程序设计;
它适用于已知循环次数的循环程序设计;
用条件控制循环:
循环终止条件是否已成立,用条件控制循环:
循环终止条件是否已成立,它适用于未知循环次数的循环程序设计。
它适用于未知循环次数的循环程序设计。
2.循环控制方法循环控制方法用计数控制循环用计数控制循环第5章汇编语言程序设计例例3在在xx单元开始的连续单元中存放有单元开始的连续单元中存放有10个无符个无符号数,从中找出中最大者送号数,从中找出中最大者送yy单元。
单元。
根据题意,我们把第一个数先送入根据题意,我们把第一个数先送入AL寄存器中,然寄存器中,然后将后将AL中的数与后面的中的数与后面的9个数逐个进行比较。
如果个数逐个进行比较。
如果AL中中的数较小,则两数交换;
如果的数较小,则两数交换;
如果AL中的数大,则不交换。
中的数大,则不交换。
在比较过程中,在比较过程中,AL中始终保持较大的数,这样,比较中始终保持较大的数,这样,比较9次后,则最大的数在次后,则最大的数在AL中,最后把中,最后把AL中的数(最大者)中的数(最大者)存入存入yy单元。
由此可画出程序的流程图由此可画出程序的流程图:
第5章汇编语言程序设计从一批数中求最大者流程图开始ALxx,BXxx的有效地址,CX9BXBX+1ALBX?
AL,BX中的数交换CXCX-1CX=0?
yyAL结束YYYYYYNNNNNN第5章汇编语言程序设计程序编写如下程序编写如下:
DATASEGMENTxxDB49,38,65,12,97,13,55,27,28,85yyDB?
DATAENDSCODESEGMENTASSUMECS:
CODE,DS:
DATASTART:
MOVAX,DATAMOVDS,AXLEABX,xxMOVAL,BXMOVCX,9第5章汇编语言程序设计LOOP1:
INCBXCMPAL,BXJAELOOP2XCHGAL,BXLOOP2:
DECCXJNZLOOP1MOVyy,ALMOVAH,4CHINT21HCODEENDSENDSTART第5章汇编语言程序设计
(2)用条件控制循环用条件控制循环有些情况无法确定循环次数,但是循环何时结束,有些情况无法确定循环次数,但是循环何时结束,可用某种条件来确定。
这时,编制程序主要是寻找控制可用某种条件来确定。
这时,编制程序主要是寻找控制条件及对控制条件的检测。
条件及对控制条件的检测。
例例5从自然数从自然数1开始累加,直到累加和大于开始累加,直到累加和大于1000为止,统计被累加的自然数的个数,并把统计的个数送为止,统计被累加的自然数的个数,并把统计的个数送入入n单元,把累加和送入单元,把累加和送入sum单元。
根据题意,被累加的自然数的个数事先是未知的,根据题意,被累加的自然数的个数事先是未知的,也就是说,循环的次数是未知的,因此不能用计数器方也就是说,循环的次数是未知的,因此不能用计数器方法控制循环。
但题目中给定一个重要条件,即累加和大法控制循环。
但题目中给定一个重要条件,即累加和大于于1000则停止累加,因此,可以根据这一条件控制循环。
则停止累加,因此,可以根据这一条件控制循环。
我们用我们用CX寄存器统计自然数的个数,用寄存器统计自然数的个数,用AX寄存器存放寄存器存放累加和,用累加和,用BX寄存器存放每次取得的自然数。
寄存器存放每次取得的自然数。
第5章汇编语言程序设计程序的流程图如下所示。
程序的流程图如下所示。
开始初始化AX0,CX0,BX0BXBX+1AXAX+BX,CXCX+1AX1000?
nCX,sumAX结束YYYNNN第5章汇编语言程序设计程序编写如下:
程序编写如下:
DATASSEGMENTnDW?
sumDW?
DATASENDSSTACKSEGMENTPARASTACKstackDWDUP(?
)STACKENDSCODESSEGMENTMAINPROCFARASSUMECX:
CODES,DS:
DATAS,SS:
STACKSTART:
PUSHDSMOVAX,0PUSHAXMOVAX,DATASMOVDS,AX第5章汇编语言程序设计MOVCX,0MOVAX,0MOVBX,0LOOPT:
INCBXADDAX,BXINCCXCMPAX,1000JLELOOPTMOVn,CXMOVsum,AXRETMAINENDPCODESENDSENDSTART第5章汇编语言程序设计3.多重循环程序设计多重循环程序设计多重循环又称循环嵌套多重循环又称循环嵌套,即循环套循环。
有些问题即循环套循环。
有些问题比较复杂比较复杂,单重循环难以解决单重循环难以解决,必须使用多重循环。
在使必须使用多重循环。
在使用多重循环时用多重循环时,必须注意以下几点:
必须注意以下几点:
内循环必须完整地包含在外循环内内循环必须完整地包含在外循环内,内外循环不内外循环不能相互交叉。
能相互交叉。
内循环既可以嵌套在外循环中内循环既可以嵌套在外循环中,也可以几个内循也可以几个内循环并列存在。
可以从内循环中直接跳到外循环,但不能环并列存在。
可以从内循环中直接跳到外循环,但不能从外循环直接跳进内循环中。
从外循环直接跳进内循环中。
防止出现防止出现“死循环死循环”。
无论是外循环。
无论是外循环,还是内循还是内循环,千万不要使循环返回到初始部分环,千万不要使循环返回到初始部分,这一点应当特别这一点应当特别注意。
注意。
第5章汇编语言程序设计每次通过外循环再次进入内循环时,初始条件每次通过外循环再次进入内循环时,初始条件必须重新设置。
必须重新设置。
例例6利用逐次求大数的方法对内存单元利用逐次求大数的方法对内存单元ARRAY开始的一字节为单位的无符号数进行从大到小排序。
开始的一字节为单位的无符号数进行从大到小排序。
根据题意,排序方法为:
编制程序如下:
4938651297135527788549496565979738384949656578788585786555493827131212ARRAYARRAYARRAYALALAL第5章汇编语言程序设计DATASEGMENTARRAYDB49,38,65,12,97,13,55,27,28,85DATAENDSCODESEGMENTASSUMECS:
MOVAX,DATAMOVDS,AXMOVDX,9LEABX,ARRAYLOOPO:
MOVAL,BXMOVSI,BX+1MOVCX,DX第5章汇编语言程序设计LOOPI:
CMPAL,SIJAENEXTXCHGAL,SINEXT:
INCSILOOPLOOPIMOVBX,ALINCBXDECDXJNZLOOPOMOVAH,4CHINT21HCODEENDSENDSTART第5章汇编语言程序设计5.6.4子程序设计子程序又称为过程,它相当于高级语言的过程或函子程序又称为过程,它相当于高级语言的过程或函数,是一个独立的程序段,能完成某些确定的功能,并数,是一个独立的程序段,能完成某些确定的功能,并能别其它程序调用。
当一个子程序不被调用能别其它程序调用。
当一个子程序不被调用,且该子程且该子程序完成确定的功能后序完成确定的功能后,便返回调用程序处。
便返回调用程序处。
1.过程的定义和调用过程的定义和调用过程的定义采用过程定义伪指令,其格式为:
过程的定义采用过程定义伪指令,其格式为:
过程名过程名PROC类型类型RET过程名过程名ENDP第5章汇编语言程序设计过程的调用采用指令语句过程的调用采用指令语句CALL,其格式为其格式为:
CALL过程名过程名段内调用段内调用CSEGSEGMENTCALLSUBTMOVAH,4CHINT21HSUBTPROCNEARRETSUBTENDPCSEGENDS第5章汇编语言程序设计段间调用段间调用XSEGSEGMENTYSEGSEGMENTCALLSUBT1CALLSUBT1MOVAH,4CHYSEGENDSINT21HSUBT1PROCFARRETSUBT1ENDPXSEGSEGMENT第5章汇编语言程序设计2.寄存器内容的保护和恢复通常主程序和过程的设计是分开的,因而他们所使用的寄存器往往会发生冲突。
为避免冲突,应在进入过程时,将该过程所用到的寄存器内容保护起来,称为保护现场。
而从过程返回主程序前,再将这些寄存器的内容恢复,称为恢复现场。
保护现场和恢复现场通常分别用堆栈压入指令和弹出指令来实现。
例如:
第5章汇编语言程序设计SUBPRPROCFARPUSHAXPUSHBXPUSHCXPUSHDXPUSHDXPUSHCXPUSHBXPUSHAXRETSUBPRENDPPUSHAXPUSHBXPUSHCXPUSHDXCALLSUBPPUSHDXPUSHCXPUSHBXPUSHAX第5章汇编语言程序设计3.主程序和构成见的参数传递主程序和构成见的参数传递主程序调用过程时,必须先将过程所需要的初始主程序调用过程时,必须先将过程所需要的初始数据设置好,这些初始数据称为过程的入口参数。
过数据设置好,这些初始数据称为过程的入口参数。
过程执行完毕返回主程序时也必须将过程运行所得的结程执行完毕返回主程序时也必须将过程运行所得的结果送给主程序,这些回送的结果称为过程的出口参数。
果送给主程序,这些回送的结果称为过程的出口参数。
过程入口参数的送入和出口参数的送出称为主程序和过程入口参数的送入和出口参数的送出称为主程序和过程间的参数传递,也称过程通信。
过程通信通常有过程间的参数传递,也称过程通信。
过程通信通常有四种方法。
四种方法。
通过寄存器传递参数通过寄存器传递参数通过变量传递参数通过变量传递参数通过地址表传递参数通过地址表传递参数通过堆栈传递参数通过堆栈传递参数第5章汇编语言程序设计4.子程序的嵌套与递归调用一个子程序调用另一个子程序叫子程序嵌套,如下图所示:
CALLCALLCALLCALLCALLCALLCALLCALLCALLRETRETRETRETRETRETRETRETRET主程序子程序1子程序2子程序n第5章汇编语言程序设计由于调用子程序时,断点地址保存在堆栈中,因此只由于调用子程序时,断点地址保存在堆栈中,因此只要有足够的堆栈空间,嵌套的层次(也称深度)是不要有足够的堆栈空间,嵌套的层次(也称深度)是不受限制的。
受限制的。
若一个子程序调用该子程序自身,则称为递归调若一个子程序调用该子程序自身,则称为
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 汇编语言 循环 程序设计