汇编语言源程序的框架结构讲课教案

上传人:yulij****0329 文档编号:137521891 上传时间:2020-07-08 格式:PPT 页数:69 大小:282.50KB
返回 下载 相关 举报
汇编语言源程序的框架结构讲课教案_第1页
第1页 / 共69页
汇编语言源程序的框架结构讲课教案_第2页
第2页 / 共69页
汇编语言源程序的框架结构讲课教案_第3页
第3页 / 共69页
汇编语言源程序的框架结构讲课教案_第4页
第4页 / 共69页
汇编语言源程序的框架结构讲课教案_第5页
第5页 / 共69页
点击查看更多>>
资源描述

《汇编语言源程序的框架结构讲课教案》由会员分享,可在线阅读,更多相关《汇编语言源程序的框架结构讲课教案(69页珍藏版)》请在金锄头文库上搜索。

1、5.1 汇编语言源程序的框架结构 编制汇编语言源程序时,首先要使用段定义伪指令和段寻址伪指令来构造一个由若干指令和数据组成的程序。构造一个源程序的框架结构有如下两种格式: 第一种格式: MOVAH,4CH ;返回DOS INT21H CODEENDS ENDBEGIN,第5章 8086/8088汇编语言程序设计,第二种格式: RET;取程序段前缀首地址 MAINENDP CODEENDS ENDBEGIN 区别:两种格式的本质区别在于返回DOS的方法不同: 对于第一种格式,采用了调用DOS系统的4CH功能,返回DOS。具体方法是:在要返回DOS处,安排如下两条指令: MOVAH,4CH INT

2、21H 对于第二格式,DOS返回方法是调用20H类型的中断服务程序。,5.2 顺序结构程序设计 顺序程序结构是指完全按照顺序逐条执行的指令序列,这种结构的流程图除了有一个开始框和结束框外,就是若干处理框,没有判断框,如图5.1所示。 图5.1 顺序程序的结构形式,例5.1:试分别用汇编语言源程序的两种框架结构编制程序,求出表达式:(X4Y)/2的值,并保存到RESULT存储单元中,其中X,Y均为字节变量。,解:完成该功能的流程图如图5.2所示: 图5.2 例5.1的功能实现流程图,BEGIN:MOVAX,DATA MOVDS,AX;DS赋初值 MOVAL,X;ALX MOVCL,2 SALAL

3、,CL;ALX4 SUBAL,Y;ALX4Y SARAL,1;AL(X4Y)/2 MOVZ,AL;存结果 MOVAH,4CH;返回DOS INT21H CODEENDS ENDBEGIN,参考程序2: DATASEGMENT XDB2 YDB4 ZDB? DATAENDS STACKSEGMENTPARASTACK DW20HDUP(0) STACKENDS CODESEGMENT ASSUMECS:CODE,DS:DATA,SS:STACK PROC1PROCFAR;使RET为远返回 ENDBEGIN,BEGIN:PUSHDS;入栈保存地址 MOVAX,0;程序段前缀的首地址 PUSHAX

4、MOVAX,DATA MOVDS,AX MOVAL,X;ALX MOVCL,2 SALAL,CL;ALX4 SUBAL,Y;ALX4Y SARAL,1;AL(X4Y)/2 MOVZ,AL;存结果 RET;取程序段前缀首地址,PROC1ENDP CODEENDS,5.3 分支结构程序设计 分支程序结构可以有两种形式,如图5.4所示,它们分别相当于高级语言程序中的IF-THEN-ELSE语句和CASE语句,它们适用于要根据不同条件做不同处理的情况。,5.3.1 用比较/测试的方法实现IF-THEN-ELSE结构 实现方法:在产生分支之前,通常用比较、测试的办法在标志寄存器中设置相应的标志位,然后再

5、选用适当的条件转移指令,以实现不同情况的分支转移。 (1)进行比较,使用比较指令: CMPDEST,SRC 该指令进行减法操作,而不保存结果,只设置标志位。 (2)进行测试,使用测试指令 TESTDEST,SRC 该指令进行逻辑与操作,而不保存结果,只设置标志位。,5.3.2 用地址表法实现CASE结构(即多路分支) 用地址表法实现CASE结构的基本思路是:将各分支程序的入口地址依次罗列形成一个地址表,让BX指向地址表的首地址,从键盘接收或其他方式获取要转到的分支号,再让BX与分支号进行运算,使BX指向对应分支入口地址,最后即可使用JMP WORD PTR BX 或JMP DWORD PTR

6、BX 指令实现所要转到的分支;程序设计流程图如图5.6所示:,图5.6 用地址表法实现多路分支的结构框图,例5.4:编程实现菜单选择,根据不同的选择做不同的事情。,解:假设有3路分支,在地址表中的入口地址分别:A0、A1、A2;具体见图5.7所示:,参考程序: DATASEGMENT MENUDB0DH,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

7、 choose the mistake!$,S0DB0DH,0AH,OK,Please answer in Chinese!$ S1DB0DH,0AH,OK,Please answer in English!$ S2DB0DH,0AH,OK,Please answer in German!$ TABDWA0,A1,A2;地址表 DATAENDS CODESEGMENT ASSUMECS:CODE,DS:DATA START:MOVAX,DATA MOVDS,AX LEADX,MENU;显示菜单 MOVAH,9 INT21H,MOVAH,1;1号DOS功能调用,接收分支号 INT21H CMPA

8、L,0;进行合法判断 JBERROR CMPAL,2 JAERROR LEABX,TAB;取地址表首址 SUBAL,30H SHLAL,1;段内转移乘以2,段间转移乘以4 XORAH,AH;AH清零 ADDBX,AX JMPWORD PTR BX;产生多分支转移,A0:LEADX,S0;各分支程序段 MOVAH,9 INT21H JMPEXIT1 A1:LEADX,S1 MOVAH,9 INT21H JMPEXIT1 A2:LEADX,S2 MOVAH,9 INT21H JMPEXIT1,ERROR:MOVDX,OFFSET ER MOVAH,9 INT21H EXIT1:MOVAH,4CH;

9、返回DOS INT21H CODEENDS ENDSTART,5.3.3 用转移表法实现CASE结构(即多路分支) 用转移表法实现CASE结构的基本思路:将转到各分支程序的转移指令依次罗列形成一个转移表,让BX指向转移表的首地址,从键盘接收或其他方式获取要转到的分支号,再让BX与分支号进行运算,使BX指向对应转移表中转到该分支的转移指令处,最后即可使用JMP BX指令实现所要转到的分支;具体见图5.8所示:,图5.8 用转移表法实现多路分支的结构框图 例5.5:编程实现菜单选择,根据不同的选择做不同的事情。 解:假设有3路分支,转移表中的转移指令分别为:JMP SHORT A0、JMP SHO

10、RT A1、JMP SHORT A2;具体见图5.9所示:,参考程序: DATASEGMENT MENUDB0DH,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 i

11、n English!$ S2DB0DH,0AH,OK,Please answer in German!$ DATAENDS CODESEGMENT ASSUMECS:CODE,DS:DATA START:MOVAX,DATA MOVDS,AX LEADX,MENU;显示菜单 MOVAH,9 INT21H,MOVAH,1;1号DOS功能调用,接收分支号 INT21H CMPAL,0 JBERROR CMPAL,2 JAERROR LEABX,TAB;取地址表首址 SUBAL,30H SHLAL,1;短转移乘以2,近转移乘以3,远转移乘以5 XORAH,AH;AH清零 ADDBX,AX,JMPBX

12、;产生多分支转移 TAB:JMPSHORTA0;转移表 JMPSHORTA1 JMPSHORTA2 A0:LEADX,S0;各分支程序段 MOVAH,9 INT21H JMPEXIT1 A1:LEADX,S1 MOVAH,9 INT21H,JMPEXIT1 A2:LEADX,S2 MOVAH,9 INT21H JMPEXIT1 ERROR:MOVDX,OFFSET ER MOVAH,9 INT21H EXIT1:MOVAH,4CH;返回DOS INT21H CODEENDS ENDSTART,5.4 循环结构程序设计 5.4.1 循环程序的组成 1.设置循环的初始状态 如置循环次数的计数值,以

13、及为循环体正常工作的初始状态等; 2.循环体 这是循环的工作主体,它由循环的工作部分及修改部分组成。3.循环控制部分 它是循环程序设计的关键,每一个循环程序必须选择一个循环控制条件来控制循环的运行和结束,通常有两种方法控制循环:用计数控制循环,用条件控制循环,5.4.2 循环程序的结构形式 循环程序有两种结构,一种是DO-WHILE结构形式,另一种是DO-UNTIL结构形式。具体见图5.10所示: DO-WHILE结构把对循环控制条件的判断放在循环的入口,先判断条件,满足条件就执行循环体,否则退出循环。 DO-UNTIL结构是先执行循环体然后再判断控制条件,不满足条件则继续执行循环操作,一旦满

14、足条件则退出循环。一般讲,如果循环次数等于0的可能,则应选择DO-WHILE结构,否则用DO-UNTIL结构。,图5.10 循环程序的结构形式,5.4.3 循环控制的方法 1.用计数控制循环 这种方法直观、方便,易于程序设计。只要在编制程序时,循环次数已知,就可以使用这种方法设计循环程序。然而更多的循环程序,在编制程序时并不能确切知道循环次数,但是知道循环次数是前面运算或操作的结果或者被存放在某内存单元中。,例5.6:试编制程序统计字节变量VAR中1的个数,并将它存入COUNT单元中。,解:要测试出VAR中1的个数就应该逐位进行测试,可根据最低位是否为1来计数,然后用移位的办法把各位数逐次移到

15、最低位去,共需要测试8次。程序流程如图5.11所示:,图5.11 例5.6的功能实现流程图,参考程序: DATASEGMENT VARDB 37H COUNTDB ? DATAENDS CODESEGMENT ASSUME CS:CODE,DS:DATA BEGIN:MOVAX,DATA MOV DS,AX MOVAL,VAR;ALVAR的值 MOVCX,8;赋循环初值 XORBL,BL;赋计数器初值,LL:TESTAL,1;测试AL的最低位 JZLL1;最低位为0转LL1 INCBL;计数器加1 LL1:SHRAL,1;逻辑右移1位 LOOPLL;循环控制 MOVCOUNT,BL;COUNT

16、计数器BL的值 MOVAH,4CH;返回DOS INT21H CODEENDS ENDBEGIN,2.用条件控制循环,例5.8:将正整数NUM插入到一个从小到大排列好顺序的正整数字节数组序列中。,分析:假设该数组的首地址和末地址分别为ARRAY_HEAD、ARRAY_END,显然在这里需要插入的是一个数,所以不一定要扫描整个数组。同时为了插入这个数据,必须要空出位置,即凡是比它大的数据都应该向地址增大的方向移动一个字节,故应该从数组的尾部向头部查找,可逐字节取出比较。值得注意的是,应该考虑正整数NUM大于或小于数组中的所有数的可能,即如果NUM大于数组中所有数,则第一次比较就可以结束查找;如果NUM小于数组中所有数,则必须及时结束查找,绝对不允许查找的范围超出数组的首地址,当然可以把数组的首地址或循环次数作为结束查找的条件。根据上述分析,可以得出程序流程如图5.13所示:,图5.13 例5.8的功能实现流程图,参考程序: NUMEQU36H DATASEGMENT ARRAYDB12H,24H,48H,60H,72H,84H YDB?

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 中学教育 > 教学课件 > 高中课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号