汇编语言流程图.pptx
《汇编语言流程图.pptx》由会员分享,可在线阅读,更多相关《汇编语言流程图.pptx(67页珍藏版)》请在咨信网上搜索。
1、5.1汇编语言源程序的框架结构汇编语言源程序的框架结构编编制制汇汇编编语语言言源源程程序序时时,首首先先要要使使用用段段定定义义伪伪指指令令和和段段寻寻址址伪伪指指令令来来构构造造一一个个由由若若干干指指令令和和数数据据组组成成的的程序。构造一个源程序的框架结构有如下两种格式:程序。构造一个源程序的框架结构有如下两种格式:第一种格式:第一种格式:MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDBEGIN第第5 5章章 8086/80888086/8088汇编语言程序设计汇编语言程序设计第二种格式:第二种格式:RET;取程序段前缀首地址;取程序段前缀首地址MAINENDPC
2、ODEENDSENDBEGIN区别:两种格式的本质区别在于返回区别:两种格式的本质区别在于返回DOS的方法不同:的方法不同:对对于于第第一一种种格格式式,采采用用了了调调用用DOS系系统统的的4CH功功能能,返返回回DOS。具具体方法是:在要返回体方法是:在要返回DOS处,安排如下两条指令:处,安排如下两条指令:MOVAH,4CHINT21H对于第二格式,对于第二格式,DOS返回方法是调用返回方法是调用20H类型的中断服务程序。类型的中断服务程序。5.2顺序结构程序设计顺序结构程序设计顺序程序结构是指完全按照顺序逐条执行的顺序程序结构是指完全按照顺序逐条执行的指令序列,这种结构的流程图除了有一
3、个开始框指令序列,这种结构的流程图除了有一个开始框和结束框外,就是若干处理框,没有判断框,如和结束框外,就是若干处理框,没有判断框,如图图5.1所示。所示。图图5.1顺序程序的结构形式顺序程序的结构形式例例5.1:试分别用汇编语言源程序的两种框架结构编制程序,求出表达试分别用汇编语言源程序的两种框架结构编制程序,求出表达式:式:(X4Y)/2的值,并保存到的值,并保存到RESULT存储单元中,其中存储单元中,其中X,Y均均为字节变量为字节变量。解:完成该功能的流程图解:完成该功能的流程图如图如图5.2所示:所示:图图5.2例例5.1的功能实现流程图的功能实现流程图参考程序参考程序1:DATAS
4、EGMENT;数据段;数据段XDB2YDB4ZDB?;定义变量;定义变量DATAENDSSTACK SEGMENTPARA STACKDW20HDUP(0)STACK ENDSCODESEGMENT;代码段;代码段ASSUMECS:CODE,DS:DATA,SS:STACKBEGIN:MOVAX,DATAMOVDS,AX;DS赋初值赋初值MOVAL,X;ALXMOVCL,2SALAL,CL;ALX4SUBAL,Y;ALX4YSARAL,1;AL(X4Y)/2MOVZ,AL;存结果;存结果MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDBEGIN参考程序参考程序2:DATA
5、SEGMENTXDB2YDB4ZDB?DATAENDSSTACK SEGMENTPARASTACKDW20HDUP(0)STACK ENDSCODESEGMENTASSUMECS:CODE,DS:DATA,SS:STACKPROC1 PROCFAR;使;使RET为远返回为远返回ENDBEGINBEGIN:PUSHDS;入栈保存地址;入栈保存地址MOVAX,0;程序段前缀的首地址;程序段前缀的首地址PUSHAXMOVAX,DATAMOVDS,AXMOVAL,X;ALXMOVCL,2SALAL,CL;ALX4SUBAL,Y;ALX4YSARAL,1;AL(X4Y)/2MOVZ,AL;存结果;存结果
6、RET;取程序段前缀首地址;取程序段前缀首地址PROC1 ENDPCODE ENDS5.3分支结构程序设计分支结构程序设计分支程序结构可以有两种形式,如图分支程序结构可以有两种形式,如图5.4所示,它们分所示,它们分别相当于高级语言程序中的别相当于高级语言程序中的IF-THEN-ELSE语句和语句和CASE语句,它们适用于要根据不同条件做不同处理的情况。语句,它们适用于要根据不同条件做不同处理的情况。5.3.1用比较用比较/测试的方法实现测试的方法实现IF-THEN-ELSE结构结构实现方法:在产生分支之前,通常用比较、测试的办实现方法:在产生分支之前,通常用比较、测试的办法在标志寄存器中设置
7、相应的标志位,然后再选用适当法在标志寄存器中设置相应的标志位,然后再选用适当的条件转移指令,以实现不同情况的分支转移。的条件转移指令,以实现不同情况的分支转移。(1)进行比较,使用比较指令:)进行比较,使用比较指令:CMPDEST,SRC该指令进行减法操作,而不保存结果,只设置标志位。该指令进行减法操作,而不保存结果,只设置标志位。(2)进行测试,使用测试指令)进行测试,使用测试指令TESTDEST,SRC该指令进行逻辑与操作,而不保存结果,只设置标志位。该指令进行逻辑与操作,而不保存结果,只设置标志位。5.3.2用地址表法实现用地址表法实现CASE结构(即多路分支)结构(即多路分支)用地址表
8、法实现用地址表法实现CASE结构的基本思路是:将各结构的基本思路是:将各分支程序的入口地址依次罗列形成一个地址表,让分支程序的入口地址依次罗列形成一个地址表,让BX指向地址表的首地址,从键盘接收或其他方式获指向地址表的首地址,从键盘接收或其他方式获取要转到的分支号,再让取要转到的分支号,再让BX与分支号进行运算,使与分支号进行运算,使BX指向对应分支入口地址,最后即可使用指向对应分支入口地址,最后即可使用JMPWORDPTRBX或或JMPDWORDPTRBX指指令实现所要转到的分支;程序设计流程图如令实现所要转到的分支;程序设计流程图如图图5.6所所示:示:图图5.6用地址表法实现多路分支的结
9、构框图用地址表法实现多路分支的结构框图例例5.4:编程实现菜单选择,根据不同的选择做不同的事情。编程实现菜单选择,根据不同的选择做不同的事情。解:假设有解:假设有3路分支,在地址表中的入口地址分别:路分支,在地址表中的入口地址分别:A0、A1、A2;具体见图;具体见图5.7所示:所示:参考程序:参考程序:DATASEGMENTMENUDB0DH,0AH,0:Chinese!DB0DH,0AH,1:English!DB0DH,0AH,2:German!DB0DH,0AH,Please choose one to answer the followingquestion:$ERDB0DH,0AH,
10、Iamsorry,youchoosethemistake!$S0DB0DH,0AH,OK,PleaseanswerinChinese!$S1DB0DH,0AH,OK,PleaseanswerinEnglish!$S2DB0DH,0AH,OK,PleaseanswerinGerman!$TABDWA0,A1,A2;地址表;地址表DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART:MOVAX,DATAMOVDS,AXLEADX,MENU;显示菜单;显示菜单MOVAH,9INT21HMOVAH,1;1号号DOS功能调用,接收分支号功能调用,接收分支号INT21
11、HCMPAL,0;进行合法判断;进行合法判断JBERRORCMPAL,2JAERRORLEABX,TAB;取地址表首址;取地址表首址SUBAL,30HSHLAL,1;段内转移乘以;段内转移乘以2,段间转移乘以,段间转移乘以4XORAH,AH;AH清零清零ADDBX,AXJMPWORDPTRBX;产生多分支转移;产生多分支转移A0:LEADX,S0;各分支程序段;各分支程序段MOVAH,9INT21HJMPEXIT1A1:LEADX,S1MOVAH,9INT21HJMPEXIT1A2:LEADX,S2MOVAH,9INT21HJMPEXIT1ERROR:MOVDX,OFFSETERMOVAH,9
12、INT21HEXIT1:MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDSTART5.3.3用转移表法实现用转移表法实现CASE结构(即多路分支)结构(即多路分支)用转移表法实现用转移表法实现CASE结构的基本思路:将转到各分支程序的转结构的基本思路:将转到各分支程序的转移指令依次罗列形成一个转移表,让移指令依次罗列形成一个转移表,让BX指向转移表的首地址,从键指向转移表的首地址,从键盘接收或其他方式获取要转到的分支号,再让盘接收或其他方式获取要转到的分支号,再让BX与分支号进行运算,与分支号进行运算,使使BX指向对应转移表中转到该分支的转移指令处,最后即可使用指向对应转
13、移表中转到该分支的转移指令处,最后即可使用JMPBX指令实现所要转到的分支;具体见指令实现所要转到的分支;具体见图图5.8所示:所示:图图5.8用转移表法实现多路分支的结构框图用转移表法实现多路分支的结构框图例例5.5:编程实现菜单选择,根据不同的选择做不同的事情。编程实现菜单选择,根据不同的选择做不同的事情。解解:假假设设有有3路路分分支支,转转移移表表中中的的转转移移指指令令分分别别为为:JMPSHORTA0、JMPSHORTA1、JMPSHORTA2;具体见;具体见图图5.9所示:所示:参考程序:参考程序:DATASEGMENTMENUDB0DH,0AH,0:Chinese!DB0DH,
14、0AH,1:English!DB0DH,0AH,2:German!DB0DH,0AH,Please choose one to answer the followingquestion:$ERDB0DH,0AH,Iamsorry,youshoosethemistake!$S0DB0DH,0AH,OK,PleaseanswerinChinese!$S1DB0DH,0AH,OK,PleaseanswerinEnglish!$S2DB0DH,0AH,OK,PleaseanswerinGerman!$DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART:MOVAX
15、,DATAMOVDS,AXLEADX,MENU;显示菜单;显示菜单MOVAH,9INT21HMOVAH,1;1号号DOS功能调用,接收分支号功能调用,接收分支号INT21HCMPAL,0JBERRORCMPAL,2JAERRORLEABX,TAB;取地址表首址;取地址表首址SUBAL,30HSHLAL,1;短转移乘以;短转移乘以2,近转移乘以,近转移乘以3,远转移乘以,远转移乘以5XORAH,AH;AH清零清零ADDBX,AXJMPBX;产生多分支转移;产生多分支转移TAB:JMPSHORT A0;转移表;转移表JMPSHORT A1JMPSHORT A2A0:LEADX,S0;各分支程序段;
16、各分支程序段MOVAH,9INT21HJMPEXIT1A1:LEADX,S1MOVAH,9INT21HJMPEXIT1A2:LEA DX,S2MOVAH,9INT21HJMPEXIT1ERROR:MOVDX,OFFSETERMOVAH,9INT21HEXIT1:MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDSTART5.4循环结构程序设计循环结构程序设计5.4.1循环程序的组成循环程序的组成1.设置循环的初始状态设置循环的初始状态如置如置循环次数的计数值,以及为循环体正常工作的初始状态等;循环次数的计数值,以及为循环体正常工作的初始状态等;2.循环体循环体这这是是循循环
17、环的的工工作作主主体体,它它由由循循环环的的工工作作部部分分及及修修改改部部分分组组成成。3.循环控制部分循环控制部分它是循环程序设计的关键,每一个循环程序必须选择一个循环它是循环程序设计的关键,每一个循环程序必须选择一个循环控制条件来控制循环的运行和结束控制条件来控制循环的运行和结束,通常有两种方法控制循环:用通常有两种方法控制循环:用计数控制循环计数控制循环,用条件控制循环用条件控制循环5.4.2循环程序的结构形式循环程序的结构形式循循环环程程序序有有两两种种结结构构,一一种种是是DO-WHILE结结构构形形式式,另一种是另一种是DO-UNTIL结构结构形式。具体见图形式。具体见图5.10
18、所示:所示:DO-WHILE结结构构把把对对循循环环控控制制条条件件的的判判断断放放在在循循环环的的入入口,先判断条件,满足条件就执行循环体,否则退出循环。口,先判断条件,满足条件就执行循环体,否则退出循环。DO-UNTIL结结构构是是先先执执行行循循环环体体然然后后再再判判断断控控制制条条件件,不不满满足足条条件件则则继继续续执执行行循循环环操操作作,一一旦旦满满足足条条件件则则退退出出循循环环。一一般般讲讲,如如果果循循环环次次数数等等于于0的的可可能能,则则应应选选择择DO-WHILE结构,否则用结构,否则用DO-UNTIL结构。结构。图图5.10循环程序的结构形式循环程序的结构形式 5
19、.4.3循环控制的方法循环控制的方法1.用计数控制循环用计数控制循环这这种种方方法法直直观观、方方便便,易易于于程程序序设设计计。只只要要在在编编制制程程序序时时,循循环环次次数数已已知知,就就可可以以使使用用这这种种方方法法设设计计循循环环程程序序。然然而而更更多多的的循循环环程程序序,在在编编制制程程序序时时并并不不能能确确切切知知道道循循环环次次数数,但但是是知知道道循循环次数是前面运算或操作的结果或者被存放在某内存单元中。环次数是前面运算或操作的结果或者被存放在某内存单元中。例例5.6:试编制程序统计字节变量试编制程序统计字节变量VAR中中1的个数,并将它的个数,并将它存入存入COUN
20、T单元中。单元中。解解:要要测测试试出出VAR中中1的的个个数数就就应应该该逐逐位位进进行行测测试试,可可根根据据最最低低位位是是否否为为1来来计计数数,然然后后用用移移位位的的办办法法把把各各位位数数逐逐次次移移到到最最低低位位去去,共需要测试共需要测试8次。程序流程如次。程序流程如图图5.11所示:所示:图图5.11例例5.6的功能实现流程图的功能实现流程图 参考程序:参考程序:DATASEGMENTVARDB37HCOUNT DB?DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATABEGIN:MOVAX,DATAMOVDS,AXMOVAL,VAR;ALVAR
21、的值的值MOVCX,8;赋循环初值;赋循环初值XORBL,BL;赋计数器初值;赋计数器初值LL:TESTAL,1;测试;测试AL的最低位的最低位JZLL1;最低位为;最低位为0转转LL1INCBL;计数器加;计数器加1LL1:SHRAL,1;逻辑右移;逻辑右移1位位LOOPLL;循环控制;循环控制MOVCOUNT,BL;COUNT计数器计数器BL的值的值MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDBEGIN2.用条件控制循环用条件控制循环例例5.8:将正整数将正整数NUM插入到一个从小到大排列好顺序的正整数插入到一个从小到大排列好顺序的正整数字节数组序列中。字节数组序
22、列中。分分析析:假假设设该该数数组组的的首首地地址址和和末末地地址址分分别别为为ARRAY_HEAD、ARRAY_END,显显然然在在这这里里需需要要插插入入的的是是一一个个数数,所所以以不不一一定定要要扫扫描描整整个个数数组组。同同时时为为了了插插入入这这个个数数据据,必必须须要要空空出出位位置置,即即凡凡是是比比它它大大的的数数据据都都应应该该向向地地址址增增大大的的方方向向移移动动一一个个字字节节,故故应应该该从从数数组组的的尾尾部部向向头头部部查查找找,可可逐逐字字节节取取出出比比较较。值值得得注注意意的的是是,应应该该考考虑虑正正整整数数NUM大大于于或或小小于于数数组组中中的的所所
23、有有数数的的可可能能,即即如如果果NUM大大于于数数组组中中所所有有数数,则则第第一一次次比比较较就就可可以以结结束束查查找找;如如果果NUM小小于于数数组组中中所所有有数数,则则必必须须及及时时结结束束查查找找,绝绝对对不不允允许许查查找找的的范范围围超超出出数数组组的的首首地地址址,当当然然可可以以把把数数组组的的首首地地址址或或循循环环次次数数作作为为结结束束查查找找的的条条件件。根根据据上上述述分分析析,可可以以得得出程序流程如出程序流程如图图5.13所示:所示:图图5.13例例5.8的功能实现流程图的功能实现流程图 参考程序:参考程序:NUMEQU36HDATASEGMENTARRA
24、Y DB12H,24H,48H,60H,72H,84HYDB?DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATABEGIN:MOVAX,DATAMOVDS,AXMOVCX,Y-ARRAY;循环次数初始化;循环次数初始化MOVAL,NUM;插入值送;插入值送ALLEASI,YDECSI;取得;取得ARRAY的最后元素的偏移地址的最后元素的偏移地址LOP:CMPARRAYSI,AL;比较;比较JLEINSERTMOVAH,ARRAYSIMOVARRAYSI+1,AH;数据交换;数据交换DECSI;修改偏移地址;修改偏移地址LOOPLOPINSERT:MOVARRAYS
25、I+1,AL;插入数据;插入数据MOVAH,4CH INT21HCODEENDSENDBEGIN5.5子程序设计子程序设计5.5.1子程序的构造子程序的构造前前面面我我们们学学习习了了过过程程定定义义伪伪指指令令,我我们们也也就就是是用用它它们们来来构构成成的的子子程程序序,其格式为:其格式为:子程序名子程序名PROC(NEAR/FAR)保存信息保存信息恢复信息恢复信息RET子程序名子程序名ENDP5.5.2子程序的调用与返回子程序的调用与返回子子程程序序的的正正确确执执行行是是由由子子程程序序的的正正确确调调用用和和返返回回保保证证的的。IBMPC机机的的CALL和和RET指指令令就就分分别
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 汇编语言 流程图
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【丰****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【丰****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。