汇编语言源程序的框架结构.ppt
《汇编语言源程序的框架结构.ppt》由会员分享,可在线阅读,更多相关《汇编语言源程序的框架结构.ppt(67页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、5.1汇编语言源程序的框架结构汇编语言源程序的框架结构编编制制汇汇编编语语言言源源程程序序时时,首首先先要要使使用用段段定定义义伪伪指指令令和和段段寻寻址址伪伪指指令令来来构构造造一一个个由由若若干干指指令令和和数数据据组组成成的的程序。构造一个源程序的框架结构有如下两种格式:程序。构造一个源程序的框架结构有如下两种格式:第一种格式:第一种格式:MOVAH,4CH;返回返回DOSINT21HCODEENDSENDBEGIN第第5 5章章 8086/8088 8086/8088汇编语言程序设计汇编语言程序设计第二种格式:第二种格式:RET;取程序段前缀首地址取程序段前缀首地址MAINENDPCO
2、DEENDSENDBEGIN区别:两种格式的本质区别在于返回区别:两种格式的本质区别在于返回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:DATA
4、SEGMENT;数据段数据段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:DATASEGM
5、ENTXDB2YDB4ZDB?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;存结果存结果RET;取程序段
6、前缀首地址取程序段前缀首地址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,Iamsorry
10、,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功能调用,接收分支号功能调用,接收分支号INT21HCMPAL,0;进
11、行合法判断进行合法判断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,9INT21HEXIT1:MOV
12、AH,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,0AH,1:English!DB0
14、DH,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,DATAMOVDS,AXLEAD
15、X,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,9INT21HJMPE
16、XIT1A1: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所示:所示:DO-WHILE结结构构把把对对
18、循循环环控控制制条条件件的的判判断断放放在在循循环环的的入入口,先判断条件,满足条件就执行循环体,否则退出循环。口,先判断条件,满足条件就执行循环体,否则退出循环。DO-UNTIL结结构构是是先先执执行行循循环环体体然然后后再再判判断断控控制制条条件件,不不满满足足条条件件则则继继续续执执行行循循环环操操作作,一一旦旦满满足足条条件件则则退退出出循循环环。一一般般讲讲,如如果果循循环环次次数数等等于于0的的可可能能,则则应应选选择择DO-WHILE结构,否则用结构,否则用DO-UNTIL结构。结构。图图5.10 循环程序的结构形式循环程序的结构形式 5.4.3循环控制的方法循环控制的方法1.用
19、计数控制循环用计数控制循环这这种种方方法法直直观观、方方便便,易易于于程程序序设设计计。只只要要在在编编制制程程序序时时,循循环环次次数数已已知知,就就可可以以使使用用这这种种方方法法设设计计循循环环程程序序。然然而而更更多多的的循循环环程程序序,在在编编制制程程序序时时并并不不能能确确切切知知道道循循环环次次数数,但但是是知知道道循循环次数是前面运算或操作的结果或者被存放在某内存单元中。环次数是前面运算或操作的结果或者被存放在某内存单元中。例例5.6:试编制程序统计字节变量试编制程序统计字节变量VAR中中1的个数,并将它的个数,并将它存入存入COUNT单元中。单元中。解解:要要测测试试出出V
20、AR中中1的的个个数数就就应应该该逐逐位位进进行行测测试试,可可根根据据最最低低位位是是否否为为1来来计计数数,然然后后用用移移位位的的办办法法把把各各位位数数逐逐次次移移到到最最低低位位去去,共需要测试共需要测试8次。程序流程如次。程序流程如图图5.11所示:所示:图图5.11 例例5.6的功能实现流程图的功能实现流程图 参考程序:参考程序:DATASEGMENTVARDB37HCOUNT DB?DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATABEGIN:MOVAX,DATAMOVDS,AXMOVAL,VAR;ALVAR的值的值MOVCX,8;赋循环初值赋循环
21、初值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大大于于或或小小于于数数组组中中的的所所有有数数的的可可能能,即即如如果果NUM大大于于数数组组
23、中中所所有有数数,则则第第一一次次比比较较就就可可以以结结束束查查找找;如如果果NUM小小于于数数组组中中所所有有数数,则则必必须须及及时时结结束束查查找找,绝绝对对不不允允许许查查找找的的范范围围超超出出数数组组的的首首地地址址,当当然然可可以以把把数数组组的的首首地地址址或或循循环环次次数数作作为为结结束束查查找找的的条条件件。根根据据上上述述分分析析,可可以以得得出程序流程如出程序流程如图图5.13所示:所示:图图5.13 例例5.8的功能实现流程图的功能实现流程图 参考程序:参考程序:NUMEQU36HDATASEGMENTARRAY DB12H,24H,48H,60H,72H,84H
24、YDB?DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATABEGIN:MOVAX,DATAMOVDS,AXMOVCX,Y-ARRAY;循环次数初始化循环次数初始化MOVAL,NUM;插入值送插入值送ALLEASI,YDECSI;取得取得ARRAY的最后元素的偏移地址的最后元素的偏移地址LOP:CMPARRAYSI,AL;比较比较JLEINSERTMOVAH,ARRAYSIMOVARRAYSI+1,AH;数据交换数据交换DECSI;修改偏移地址修改偏移地址LOOPLOPINSERT:MOVARRAYSI+1,AL;插入数据插入数据MOVAH,4CH INT21HCO
25、DEENDSENDBEGIN5.5子程序设计子程序设计5.5.1子程序的构造子程序的构造前前面面我我们们学学习习了了过过程程定定义义伪伪指指令令,我我们们也也就就是是用用它它们们来来构构成成的的子子程程序序,其格式为:其格式为:子程序名子程序名PROC(NEAR/FAR)保存信息保存信息恢复信息恢复信息RET子程序名子程序名ENDP5.5.2子程序的调用与返回子程序的调用与返回子子程程序序的的正正确确执执行行是是由由子子程程序序的的正正确确调调用用和和返返回回保保证证的的。IBMPC机机的的CALL和和RET指指令令就就分分别别完完成成了了子子程程序序的的调调用用和返回功能。和返回功能。1.调
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 汇编语言 源程序 框架结构
限制150内