《汇编语言流程图++.ppt》由会员分享,可在线阅读,更多相关《汇编语言流程图++.ppt(67页珍藏版)》请在优知文库上搜索。
1、5.1 汇编语言源程序的框架结构汇编语言源程序的框架结构 编制汇编语言源程序时,首先要使用段定义伪指令编制汇编语言源程序时,首先要使用段定义伪指令和段寻址伪指令来构造一个由若干指令和数据组成的和段寻址伪指令来构造一个由若干指令和数据组成的程序。构造一个源程序的框架结构有如下两种格式:程序。构造一个源程序的框架结构有如下两种格式:第一种格式:第一种格式:MOVAH,4CH ;返回;返回DOSINT21HCODEENDSENDBEGIN第第5 5章章 8086/80888086/8088汇编语言程序设计汇编语言程序设计第二种格式:第二种格式:RET;取程序段前缀首地址;取程序段前缀首地址MAINE
2、NDPCODEENDSENDBEGIN区别:两种格式的本质区别在于返回区别:两种格式的本质区别在于返回DOS的方法不同:的方法不同:对于第一种格式,对于第一种格式,采用了调用采用了调用DOS系统的系统的4CH功能,返回功能,返回DOS。具体方法是:在要返回具体方法是:在要返回DOS处,安排如下两条指令:处,安排如下两条指令:MOVAH,4CHINT21H对于第二格式,对于第二格式,DOS返回方法是调用返回方法是调用20H类型的中断服务程序。类型的中断服务程序。5.2 顺序结构程序设计顺序结构程序设计 顺序程序结构是指完全按照顺序逐条执行的顺序程序结构是指完全按照顺序逐条执行的指令序列,这种结构
3、的流程图除了有一个开始框指令序列,这种结构的流程图除了有一个开始框和结束框外,就是若干处理框,没有判断框,如和结束框外,就是若干处理框,没有判断框,如图图5.1所示。所示。图图5.1顺序程序的结构形式顺序程序的结构形式语 句 3语 句 2结 束开 始语 句 1例例5.1:试分别用汇编语言源程序的两种框架结构编制程序,求出表达试分别用汇编语言源程序的两种框架结构编制程序,求出表达式:式:(X4Y)/2的值,并保存到的值,并保存到RESULT存储单元中,其中存储单元中,其中X,Y均均为字节变量为字节变量。解:完成该功能的流程图解:完成该功能的流程图如图如图5.2所示:所示:图图5.2 例例5.1的
4、功能实现流程图的功能实现流程图 Z(AL)AL(AL)/2AL(AL)-(Y)AL(AL)4AL(X)结束开始参考程序参考程序1:DATASEGMENT;数据段;数据段XDB2YDB4ZDB?;定义变量;定义变量DATAENDSSTACK SEGMENT PARA STACKDW20HDUP(0)STACK ENDSCODESEGMENT;代码段;代码段ASSUME CS:CODE,DS:DATA,SS:STACKBEGIN:MOVAX,DATAMOVDS,AX;DS赋初值赋初值MOVAL,X;ALXMOVCL,2SALAL,CL;ALX4SUBAL,Y;ALX4YSARAL,1;AL(X4Y
5、)/2MOVZ,AL;存结果;存结果MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDBEGIN参考程序参考程序2:DATASEGMENTXDB2YDB4ZDB?DATAENDSSTACK SEGMENTPARASTACKDW20HDUP(0)STACK ENDSCODESEGMENTASSUMECS:CODE,DS:DATA,SS:STACKPROC1 PROCFAR;使;使RET为远返回为远返回ENDBEGINBEGIN: PUSHDS;入栈保存地址;入栈保存地址MOVAX,0;程序段前缀的首地址;程序段前缀的首地址PUSHAXMOVAX,DATAMOVDS,AXMOV
6、AL,X;ALXMOVCL,2SALAL,CL;ALX4SUBAL,Y;ALX4YSARAL,1;AL(X4Y)/2MOVZ,AL;存结果;存结果RET;取程序段前缀首地址;取程序段前缀首地址PROC1 ENDPCODE ENDS5.3 分支结构程序设计分支结构程序设计 分支程序结构可以有两种形式,如图分支程序结构可以有两种形式,如图5.4所示,它们分所示,它们分别相当于高级语言程序中的别相当于高级语言程序中的IF-THEN-ELSE语句和语句和CASE语句,它们适用于要根据不同条件做不同处理的情况。语句,它们适用于要根据不同条件做不同处理的情况。语 句 判 定 条 件语 句 CASE结 构语
7、 句 nIF-THEN-ELSE结 构语 句 判 定 条 件语 句 5.3.1 用比较用比较/测试的方法实现测试的方法实现IF-THEN-ELSE结构结构 实现方法:在产生分支之前,通常用比较、测试的办实现方法:在产生分支之前,通常用比较、测试的办法在标志寄存器中设置相应的标志位,然后再选用适当法在标志寄存器中设置相应的标志位,然后再选用适当的条件转移指令,以实现不同情况的分支转移。的条件转移指令,以实现不同情况的分支转移。(1)进行比较,使用比较指令:)进行比较,使用比较指令:CMPDEST,SRC该指令进行减法操作,而不保存结果,只设置标志位。该指令进行减法操作,而不保存结果,只设置标志位
8、。(2)进行测试,使用测试指令)进行测试,使用测试指令TESTDEST,SRC该指令进行逻辑与操作,而不保存结果,只设置标志位。该指令进行逻辑与操作,而不保存结果,只设置标志位。5.3.2 用地址表法实现用地址表法实现CASE结构(即多路分支)结构(即多路分支) 用地址表法实现用地址表法实现CASE结构的基本思路是:将各结构的基本思路是:将各分支程序的入口地址依次罗列形成一个地址表,让分支程序的入口地址依次罗列形成一个地址表,让BX指向地址表的首地址,从键盘接收或其他方式获指向地址表的首地址,从键盘接收或其他方式获取要转到的分支号,再让取要转到的分支号,再让BX与分支号进行运算,使与分支号进行
9、运算,使BX指向对应分支入口地址,最后即可使用指向对应分支入口地址,最后即可使用JMP WORD PTR BX 或或JMP DWORD PTR BX 指指令实现所要转到的分支;程序设计流程图如令实现所要转到的分支;程序设计流程图如图图5.6所所示:示:建 立 地 址 表求 出 分 支 号 所 对 应 分 支 在 地 址 表 的 存 放 地 址 ,并 送 BX接 收 分 支 号 JMPWORD/DWORD PTR BX图图5.6用地址表法实现多路分支的结构框图用地址表法实现多路分支的结构框图例例5.4:编程实现菜单选择,根据不同的选择做不同的事情。编程实现菜单选择,根据不同的选择做不同的事情。
10、解:假设有解:假设有3路分支,在地址表中的入口地址分别:路分支,在地址表中的入口地址分别:A0、A1、A2;具体见图;具体见图5.7所示:所示:A2-HA2-LA1-HA1-LA0-H:TABA0-L:参考程序:参考程序:DATASEGMENTMENUDB0DH,0AH,0:Chinese!DB0DH,0AH,1:English!DB0DH,0AH,2: German!DB0DH,0AH,Please choose one to answer the following question:$ERDB 0DH,0AH,I am sorry,you choose the mistake!$S0DB
11、0DH,0AH,OK,Please answer in Chinese!$S1DB0DH,0AH,OK,Please answer in English!$S2DB0DH,0AH,OK,Please answer in German!$TABDWA0,A1,A2;地址表;地址表DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART: MOVAX,DATAMOVDS,AXLEADX,MENU;显示菜单;显示菜单MOVAH,9INT21HMOVAH,1;1号号DOS功能调用,接收分支号功能调用,接收分支号INT21HCMPAL,0;进行合法判断;进行合法判断JB
12、ERRORCMPAL,2JAERRORLEABX,TAB;取地址表首址;取地址表首址SUBAL,30HSHLAL,1;段内转移乘以;段内转移乘以2,段间转移乘以,段间转移乘以4XORAH,AH;AH清零清零ADDBX,AXJMPWORD PTR BX;产生多分支转移;产生多分支转移 A0:LEADX,S0;各分支程序段;各分支程序段MOVAH,9INT21HJMPEXIT1A1:LEADX,S1MOVAH,9INT21HJMPEXIT1A2:LEADX,S2MOVAH,9INT21HJMPEXIT1ERROR:MOVDX,OFFSET ERMOVAH,9INT21HEXIT1: MOVAH,4
13、CH;返回;返回DOSINT21HCODEENDSENDSTART5.3.3 用转移表法实现用转移表法实现CASE结构(即多路分支)结构(即多路分支) 用转移表法实现用转移表法实现CASE结构的基本思路:将转到各分支程序的转结构的基本思路:将转到各分支程序的转移指令依次罗列形成一个转移表,让移指令依次罗列形成一个转移表,让BX指向转移表的首地址,从键指向转移表的首地址,从键盘接收或其他方式获取要转到的分支号,再让盘接收或其他方式获取要转到的分支号,再让BX与分支号进行运算,与分支号进行运算,使使BX指向对应转移表中转到该分支的转移指令处,最后即可使用指向对应转移表中转到该分支的转移指令处,最后
14、即可使用JMP BX指令实现所要转到的分支;具体见指令实现所要转到的分支;具体见图图5.8所示:所示:建立地址表求出分支号所对应分支在地址表的存放地 址,并送BX接收分支号JMP BX图图5.8 用转移表法实现多路分支的结构框图用转移表法实现多路分支的结构框图例例5.5:编程实现菜单选择,根据不同的选择做不同的事情。编程实现菜单选择,根据不同的选择做不同的事情。解:假设有解:假设有3路分支,转移表中的转移指令分别为:路分支,转移表中的转移指令分别为:JMP SHORT A0、JMP SHORT A1、JMP SHORT A2;具体见;具体见图图5.9所示:所示:JMP SHORT A2JMP
15、SHORT A1JMP SHORT A0:TAB:参考程序:参考程序:DATASEGMENTMENUDB0DH,0AH,0:Chinese!DB0DH,0AH,1:English!DB0DH,0AH,2: German!DB0DH,0AH,Please choose one to answer the following question:$ER DB 0DH,0AH,I am sorry,you shoose the mistake!$S0DB0DH,0AH,OK,Please answer in Chinese!$S1DB0DH,0AH,OK,Please answer in Englis
16、h!$S2DB0DH,0AH,OK,Please answer in German!$DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART: MOVAX,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;各分支程序段;各分支程序段MOVAH,9INT21HJMPEXIT1A1:LEADX,S1MOVAH,9INT21HJMPEXIT1A2:LEA DX,S2MOVAH,9INT21HJMPEXIT1ERROR:MOVDX,