书签 分享 收藏 举报 版权申诉 / 77
上传文档赚钱

类型第5章80868088汇编语言程序设计课件.ppt

  • 上传人(卖家):晟晟文业
  • 文档编号:3861250
  • 上传时间:2022-10-19
  • 格式:PPT
  • 页数:77
  • 大小:311.18KB
  • 【下载声明】
    1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
    2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
    3. 本页资料《第5章80868088汇编语言程序设计课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
    4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
    5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
    配套讲稿:

    如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

    特殊限制:

    部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

    关 键  词:
    80868088 汇编语言 程序设计 课件
    资源描述:

    1、编制汇编语言源程序时,首先要使用段定义伪指令编制汇编语言源程序时,首先要使用段定义伪指令和段寻址伪指令来构造一个由若干指令和数据组成的和段寻址伪指令来构造一个由若干指令和数据组成的程序。构造一个源程序的框架结构有如下两种格式:程序。构造一个源程序的框架结构有如下两种格式:第一种格式:第一种格式:MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDBEGIN第第5 5章章 8086/8088 8086/8088汇编语言程序设计汇编语言程序设计5.1汇编语言源程序的框架结构汇编语言源程序的框架结构第二种格式:第二种格式:RET;取程序段前缀首地址;取程序段前缀首地址MAINEND

    2、PCODEENDSENDBEGIN区别:两种格式的本质区别在于返回区别:两种格式的本质区别在于返回DOS的方法不同:的方法不同:对于第一种格式,对于第一种格式,采用了调用采用了调用DOS系统的系统的4CH功能,返回功能,返回DOS。具体方法是:在要返回具体方法是:在要返回DOS处,安排如下两条指令:处,安排如下两条指令:MOVAH,4CHINT21H对于第二格式,对于第二格式,DOS返回方法是调用返回方法是调用20H类型的中断服务程序。类型的中断服务程序。5.1汇编语言源程序的框架结构汇编语言源程序的框架结构(续续)顺序程序结构是指完全按照顺序逐条执行的顺序程序结构是指完全按照顺序逐条执行的指

    3、令序列,这种结构的流程图除了有一个开始框指令序列,这种结构的流程图除了有一个开始框和结束框外,就是若干处理框,没有判断框。和结束框外,就是若干处理框,没有判断框。图图5.1 顺序程序的结构形式顺序程序的结构形式 语 句 3语 句 2结 束开 始语 句 15.2顺序结构程序设计顺序结构程序设计例例5.1:试分别用汇编语言源程序的两种框架结构编制程序,求出表达试分别用汇编语言源程序的两种框架结构编制程序,求出表达式:式:(X4Y)/2的值,并保存到的值,并保存到RESULT存储单元中,其中存储单元中,其中X,Y均均为字节变量为字节变量。解:完成该功能的流程图解:完成该功能的流程图如图如图5.2所示

    4、:所示:图图5.2例例5.1的功能实现流程图的功能实现流程图Z (A L)A L (A L)/2A L (A L)-(Y)A L (A L)4A L (X)结 束开 始5.2顺序结构程序设计(续)顺序结构程序设计(续)参考程序参考程序1:DATASEGMENT;数据段;数据段XDB2YDB4ZDB?;定义变量;定义变量DATAENDSSTACK SEGMENTPARA STACKDW20HDUP(0)STACK ENDSCODESEGMENT;代码段;代码段ASSUMECS:CODE,DS:DATA,SS:STACK5.2顺序结构程序设计(续)顺序结构程序设计(续)BEGIN:MOVAX,DA

    5、TAMOVDS,AX;DS赋初值赋初值MOVAL,X;ALXMOVCL,2SALAL,CL;ALX4SUBAL,Y;ALX4YSARAL,1;AL(X4Y)/2MOVZ,AL;存结果;存结果MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDBEGIN5.2顺序结构程序设计(续)顺序结构程序设计(续)参考程序参考程序2:DATASEGMENTXDB2YDB4ZDB?DATAENDSSTACK SEGMENTPARASTACKDW20HDUP(0)STACK ENDSCODESEGMENTASSUMECS:CODE,DS:DATA,SS:STACKPROC1 PROCFAR;使

    6、;使RET为远返回为远返回ENDBEGIN5.2顺序结构程序设计(续)顺序结构程序设计(续)BEGIN:PUSHDS;入栈保存地址;入栈保存地址MOVAX,0;程序段前缀的首地址;程序段前缀的首地址PUSHAXMOVAX,DATAMOVDS,AXMOVAL,X;ALXMOVCL,2SALAL,CL;ALX4SUBAL,Y;ALX4YSARAL,1;AL(X4Y)/2MOVZ,AL;存结果;存结果RET;取程序段前缀首地址;取程序段前缀首地址5.2顺序结构程序设计(续)顺序结构程序设计(续)PROC1 ENDPCODE ENDS5.2顺序结构程序设计(续)顺序结构程序设计(续)分支程序结构可以有

    7、两种形式,如图分支程序结构可以有两种形式,如图5.4所示,它们分所示,它们分别相当于高级语言程序中的别相当于高级语言程序中的IF-THEN-ELSE语句和语句和CASE语句,它们适用于要根据不同条件做不同处理的情况。语句,它们适用于要根据不同条件做不同处理的情况。语句判定条件语句CASE结构语句nIF-THEN-ELSE结构语句判定条件语句5.3分支结构程序设计分支结构程序设计实现方法:在产生分支之前,通常用比较、测试的办实现方法:在产生分支之前,通常用比较、测试的办法在标志寄存器中设置相应的标志位,然后再选用适当法在标志寄存器中设置相应的标志位,然后再选用适当的条件转移指令,以实现不同情况的

    8、分支转移。的条件转移指令,以实现不同情况的分支转移。(1)进行比较,使用比较指令:)进行比较,使用比较指令:CMPDEST,SRC该指令进行减法操作,而不保存结果,只设置标志位。该指令进行减法操作,而不保存结果,只设置标志位。(2)进行测试,使用测试指令)进行测试,使用测试指令TESTDEST,SRC该指令进行逻辑与操作,而不保存结果,只设置标志位。该指令进行逻辑与操作,而不保存结果,只设置标志位。5.3.1用比较用比较/测试的方法实现测试的方法实现IF-THEN-ELSE结构结构用地址表法实现用地址表法实现CASE结构的基本思路是:将各结构的基本思路是:将各分支程序的入口地址依次罗列形成一个

    9、地址表,让分支程序的入口地址依次罗列形成一个地址表,让BX指向地址表的首地址,从键盘接收或其他方式获指向地址表的首地址,从键盘接收或其他方式获取要转到的分支号,再让取要转到的分支号,再让BX与分支号进行运算,使与分支号进行运算,使BX指向对应分支入口地址,最后即可使用指向对应分支入口地址,最后即可使用JMPWORDPTRBX或或JMPDWORDPTRBX指指令实现所要转到的分支;程序设计流程图如令实现所要转到的分支;程序设计流程图如图图5.6所所示:示:5.3.2用地址表法实现用地址表法实现CASE结构(即多路分支)结构(即多路分支)建 立 地 址 表求 出 分 支 号 所 对 应 分 支 在

    10、 地 址 表 的 存 放 地 址,并 送 B X接 收 分 支 号 J M PW O R D/D W O R D P T R B X 图图5.6 用地址表法实现多路分支的结构框图用地址表法实现多路分支的结构框图 例例5.4:编程实现菜单选择,根据不同的选择做不同的事情。编程实现菜单选择,根据不同的选择做不同的事情。解:假设有解:假设有3路分支,在地址表中的入口地址分别:路分支,在地址表中的入口地址分别:A0、A1、A2;具体见图;具体见图5.7所示:所示:5.3.2用地址表法实现用地址表法实现CASE结构(续)结构(续)A 2-HA 2-LA 1-HA 1-LA 0-H:T A BA 0-L:

    11、参考程序:参考程序:DATASEGMENTMENUDB0DH,0AH,0:Chinese!DB0DH,0AH,1:English!DB0DH,0AH,2:German!DB0DH,0AH,Pleasechooseonetoanswerthefollowingquestion:$ERDB0DH,0AH,Iamsorry,youchoosethemistake!$5.3.2用地址表法实现用地址表法实现CASE结构(续)结构(续)S0DB0DH,0AH,OK,PleaseanswerinChinese!$S1DB0DH,0AH,OK,PleaseanswerinEnglish!$S2DB0DH,0A

    12、H,OK,PleaseanswerinGerman!$TABDWA0,A1,A2;地址表;地址表DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART:MOVAX,DATAMOVDS,AXLEADX,MENU;显示菜单;显示菜单MOVAH,9INT21H5.3.2用地址表法实现用地址表法实现CASE结构(续)结构(续)MOVAH,1;1号号DOS功能调用,接收分支号功能调用,接收分支号INT21HCMPAL,0;进行合法判断;进行合法判断JBERRORCMPAL,2JAERRORLEABX,TAB;取地址表首址;取地址表首址SUBAL,30HSHLAL,1;

    13、段内转移乘以;段内转移乘以2,段间转移乘以,段间转移乘以4XORAH,AH;AH清零清零ADDBX,AXJMPWORDPTRBX;产生多分支转移;产生多分支转移5.3.2用地址表法实现用地址表法实现CASE结构(续)结构(续)A0:LEADX,S0;各分支程序段;各分支程序段MOVAH,9INT21HJMPEXIT1A1:LEADX,S1MOVAH,9INT21HJMPEXIT1A2:LEADX,S2MOVAH,9INT21HJMPEXIT15.3.2用地址表法实现用地址表法实现CASE结构(续)结构(续)ERROR:MOVDX,OFFSETERMOVAH,9INT21HEXIT1:MOVAH

    14、,4CH;返回;返回DOSINT21HCODEENDSENDSTART5.3.2用地址表法实现用地址表法实现CASE结构(续)结构(续)用转移表法实现用转移表法实现CASE结构的基本思路:结构的基本思路:将转到各将转到各分支程序的转移指令依次罗列形成一个转移表,让分支程序的转移指令依次罗列形成一个转移表,让BX指向转移表的首地址,从键盘接收或其他方式指向转移表的首地址,从键盘接收或其他方式获取要转到的分支号,再让获取要转到的分支号,再让BX与分支号进行运算,与分支号进行运算,使使BX指向对应转移表中转到该分支的转移指令处,指向对应转移表中转到该分支的转移指令处,最后即可使用最后即可使用JMPB

    15、X指令实现所要转到的分支;指令实现所要转到的分支;具体见具体见图图5.8所示:所示:5.3.3用转移表法实现用转移表法实现CASE结构(续)结构(续)建 立 地 址 表求 出 分 支 号 所 对 应 分支 在 地 址 表 的 存 放 地 址,并 送 B X接 收 分 支 号J M P B X图图5.8用转移表法实现多路分支的结构框图用转移表法实现多路分支的结构框图例例5.5:编程实现菜单选择,根据不同的选择做不同的事情。编程实现菜单选择,根据不同的选择做不同的事情。解:假设有解:假设有3路分支,转移表中的转移指令分别为:路分支,转移表中的转移指令分别为:JMPSHORTA0、JMPSHORTA

    16、1、JMPSHORTA2;具体见;具体见图图5.9所示:所示:5.3.3用转移表法实现用转移表法实现CASE结构(续)结构(续)JMP SHORT A2JMP SHORT A1JMP SHORT A0:TAB:参考程序:参考程序:DATASEGMENTMENUDB0DH,0AH,0:Chinese!DB0DH,0AH,1:English!DB0DH,0AH,2:German!DB0DH,0AH,Pleasechooseonetoanswerthefollowingquestion:$5.3.3用转移表法实现用转移表法实现CASE结构(续)结构(续)ERDB0DH,0AH,Iamsorry,yo

    17、ushoosethemistake!$S0DB0DH,0AH,OK,PleaseanswerinChinese!$S1DB0DH,0AH,OK,PleaseanswerinEnglish!$S2DB0DH,0AH,OK,PleaseanswerinGerman!$DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART:MOVAX,DATAMOVDS,AXLEADX,MENU;显示菜单;显示菜单MOVAH,9INT21H5.3.3用转移表法实现用转移表法实现CASE结构(续)结构(续)MOVAH,1;1号号DOS功能调用,接收分支号功能调用,接收分支号INT2

    18、1HCMPAL,0JBERRORCMPAL,2JAERRORLEABX,TAB;取地址表首址;取地址表首址SUBAL,30HSHLAL,1;短转移乘以;短转移乘以2,近转移乘以,近转移乘以3,远转移乘以,远转移乘以5XORAH,AH;AH清零清零ADDBX,AX5.3.3用转移表法实现用转移表法实现CASE结构(续)结构(续)JMPBX;产生多分支转移;产生多分支转移TAB:JMPSHORT A0;转移表;转移表JMPSHORT A1JMPSHORT A2A0:LEADX,S0;各分支程序段;各分支程序段MOVAH,9INT21HJMPEXIT1A1:LEADX,S1MOVAH,9INT21H

    19、5.3.3用转移表法实现用转移表法实现CASE结构(续)结构(续)JMPEXIT1A2:LEA DX,S2MOVAH,9INT21HJMPEXIT1ERROR:MOVDX,OFFSETERMOVAH,9INT21HEXIT1:MOVAH,4CH;返回;返回DOSINT21HCODEENDSENDSTART5.3.3用转移表法实现用转移表法实现CASE结构(续)结构(续)1.设置循环的初始状态设置循环的初始状态如置如置循环次数的计数值,以及为循环体正常工作的初始状态等;循环次数的计数值,以及为循环体正常工作的初始状态等;2.循环体循环体这是循环的工作主体,它由循环的工作部分及修改部分组成。这是循

    20、环的工作主体,它由循环的工作部分及修改部分组成。3.循环控制部分循环控制部分 它是循环程序设计的关键,每一个循环程序必须选择一个循环它是循环程序设计的关键,每一个循环程序必须选择一个循环控制条件来控制循环的运行和结束控制条件来控制循环的运行和结束,通常有两种方法控制循环:通常有两种方法控制循环:用用计数控制循环计数控制循环,用条件控制循环用条件控制循环 5.4循环结构程序设计循环结构程序设计5.4.1循环程序的组成循环程序的组成循环程序有两种结构:一种是循环程序有两种结构:一种是DO-WHILE结构形式,另一结构形式,另一种是种是DO-UNTIL结构结构形式。具体见图形式。具体见图5.10所示

    21、:所示:DO-WHILE结构把对循环控制条件的判断放在循环的入结构把对循环控制条件的判断放在循环的入口,先判断条件,满足条件就执行循环体,否则退出循环。口,先判断条件,满足条件就执行循环体,否则退出循环。DO-UNTIL结构是先执行循环体然后再判断控制条件,结构是先执行循环体然后再判断控制条件,不满足条件则继续执行循环操作,一旦满足条件则退出循不满足条件则继续执行循环操作,一旦满足条件则退出循环。一般讲,如果循环次数等于环。一般讲,如果循环次数等于0的可能,则应选择的可能,则应选择DO-WHILE结构,否则用结构,否则用DO-UNTIL结构。结构。5.4.2循环程序的结构形式循环程序的结构形式

    22、DO-(当 型 循 环,当 条 件 成 立 进 入 循 环)循 环 体N循 环 条 件 判 断?Y循 环 初 始 设 置(直 到 型 循 环,直 到 条 件 成 立 退 出 循 环)YNDO-UNTIL循 环 条 件 判 断?循 环 体循 环 初 始 设 置图图5.10 循环程序的结构形式循环程序的结构形式 5.4.2循环程序的结构形式(续)循环程序的结构形式(续)这种方法直观、方便,易于程序设计。只要在编制程序时,循这种方法直观、方便,易于程序设计。只要在编制程序时,循环环次数已知,就可以使用这种方法设计循环程序。然而更多的次数已知,就可以使用这种方法设计循环程序。然而更多的循环程序,在编制

    23、循环程序,在编制程序时并不能确切知道循环次数,但是知道程序时并不能确切知道循环次数,但是知道循环次数是前面运算或操作的结果或者被存放在某内存单元中。循环次数是前面运算或操作的结果或者被存放在某内存单元中。5.4.3循环控制的方法循环控制的方法1.用计数控制循环用计数控制循环例例5.6:试编制程序统计字节变量试编制程序统计字节变量VAR中中1的个数,并将它的个数,并将它存入存入COUNT单元中。单元中。解:要测试出解:要测试出VAR中中1的个数就应该逐位进行测试,可根据最低位的个数就应该逐位进行测试,可根据最低位是否为是否为1来计数,然后用移位的办法把各位数逐次移到最低位去,来计数,然后用移位的

    24、办法把各位数逐次移到最低位去,共需要测试共需要测试8次。程序流程如次。程序流程如图图5.11所示:所示:1.用计数控制循环用计数控制循环5.4.3循环控制的方法(续)循环控制的方法(续)YN(C X)=(C X)-1A L 逻 辑 右 移 一 位NC X=0?结 束Y(B L)=(B L)+1C O U N T (B L)循 环 次 数 C X 0计 数 初 值 B L 0 A L V A R开 始A L 最 低 位是 否 为 1?图图5.11 例例5.6的功能实现流程图的功能实现流程图 5.4.3循环控制的方法(续)循环控制的方法(续)参考程序:参考程序:DATASEGMENTVARDB37

    25、HCOUNT DB?DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATABEGIN:MOVAX,DATAMOVDS,AXMOVAL,VAR;ALVAR的值的值MOVCX,8;赋循环初值;赋循环初值XORBL,BL;赋计数器初值;赋计数器初值5.4.3循环控制的方法(续)循环控制的方法(续)LL:TESTAL,1;测试;测试AL的最低位的最低位JZLL1;最低位为;最低位为0转转LL1INCBL;计数器加;计数器加1LL1:SHRAL,1;逻辑右移;逻辑右移1位位LOOPLL;循环控制;循环控制MOVCOUNT,BL;COUNT计数器计数器BL的值的值MOVAH,4C

    26、H;返回;返回DOSINT21HCODEENDSENDBEGIN5.4.3循环控制的方法(续)循环控制的方法(续)2.用条件控制循环用条件控制循环例例5.8:将正整数将正整数NUM插入到一个从小到大排列好顺序的正整数插入到一个从小到大排列好顺序的正整数字节数组序列中。字节数组序列中。分析:分析:根据上述分析,可以得出程序流程如根据上述分析,可以得出程序流程如图图5.13所示:所示:5.4.3循环控制的方法(续)循环控制的方法(续)YN修 改 地 址 指 针:S I (S I)-1循 环 次 数 计 数:C X (C X)-1NC X=0?结 束Y(A R R A Y S I )与(A R R

    27、A Y S I+1 )交 换A R R A Y S I+1 A LA L 0 插 入 数 据 N U MS I 0 数 组 末 偏 移 地 址C X 数 组 元 素 个 数开 始(A R R A Y S I )(A L)?图图5.13 例例5.8的功能实现流程图的功能实现流程图 5.4.3循环控制的方法(续)循环控制的方法(续)参考程序:参考程序:NUMEQU36HDATASEGMENTARRAY DB12H,24H,48H,60H,72H,84HYDB?DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATABEGIN:MOVAX,DATAMOVDS,AXMOVCX,

    28、Y-ARRAY;循环次数初始化;循环次数初始化MOVAL,NUM;插入值送;插入值送AL5.4.3循环控制的方法(续)循环控制的方法(续)LEASI,YDECSI;取得;取得ARRAY的最后元素的偏移地址的最后元素的偏移地址LOP:CMPARRAYSI,AL;比较;比较JLEINSERTMOVAH,ARRAYSIMOVARRAYSI+1,AH;数据交换;数据交换DECSI;修改偏移地址;修改偏移地址LOOPLOPINSERT:MOVARRAYSI+1,AL;插入数据;插入数据MOVAH,4CH5.4.3循环控制的方法(续)循环控制的方法(续)INT21HCODEENDSENDBEGIN5.4.

    29、3循环控制的方法(续)循环控制的方法(续)5.5子程序设计子程序设计前面我们学习了过程定义伪指令,我们也就是用它们来构成的子程序,前面我们学习了过程定义伪指令,我们也就是用它们来构成的子程序,其格式为:其格式为:子程序名子程序名PROC(NEAR/FAR)保存信息保存信息恢复信息恢复信息RET子程序名子程序名ENDP5.5.1子程序的构造子程序的构造IBMPC机的机的CALL和和RET指令就分别完成了子程序的调指令就分别完成了子程序的调用和返回功能。用和返回功能。1.调用指令:调用指令:CALL过程名过程名执行执行CALL指令,首先保留断点地址于堆栈中,然后转指令,首先保留断点地址于堆栈中,然

    30、后转移到目标单元,它对移到目标单元,它对PSW无影响。无影响。2.返回指令:返回指令:RET 一个子程序执行的最后一条指令必定是返回指令一个子程序执行的最后一条指令必定是返回指令RET,用以返回到调用子程序的断点处。但在位置上并不一定就用以返回到调用子程序的断点处。但在位置上并不一定就是是最后一条指令。是是最后一条指令。5.5子程序设计(续)子程序设计(续)5.5.2子程序的调用与返回子程序的调用与返回v子程序必须具有通用性子程序必须具有通用性v注意保存信息和恢复信息注意保存信息和恢复信息v选用适当的方法在子程序和主程序之间的选用适当的方法在子程序和主程序之间的进行参数传递进行参数传递5.5子

    31、程序设计(续)子程序设计(续)5.5.3编制子程序的要求编制子程序的要求主程序与子程序之间的信息传送称为参数传递。主程序与子程序之间的信息传送称为参数传递。它可以有以下三种:它可以有以下三种:用寄存器传递参数用寄存器传递参数用地址表传递参数用地址表传递参数用堆栈传递参数用堆栈传递参数 5.5子程序设计(续)子程序设计(续)5.5.3编制子程序的要求编制子程序的要求v参数传递参数传递1宏定义宏定义宏在使用前必须先进行宏定义。宏定义格式为:宏在使用前必须先进行宏定义。宏定义格式为:宏指令名宏指令名MACRO形式参数,形式参形式参数,形式参数,数,宏体宏体ENDM其中,宏指令名:宏定义的名字,不可缺

    32、省,宏调用时其中,宏指令名:宏定义的名字,不可缺省,宏调用时要使用它,第一个符号必须是字母,其后可以是字母或要使用它,第一个符号必须是字母,其后可以是字母或数字数字5.6高级汇编语言技术高级汇编语言技术5.6.1宏汇编宏汇编MACROENDM:宏定义伪指令助记符,不可:宏定义伪指令助记符,不可缺省。它们成对出现,表示宏定义的开始和结束,缺省。它们成对出现,表示宏定义的开始和结束,ENDM前不带宏指令名。前不带宏指令名。宏体:一段有独立功能的程序代码段。宏体:一段有独立功能的程序代码段。形式参数:又称哑元,各个哑元之间用逗号隔开,形式参数:又称哑元,各个哑元之间用逗号隔开,可以缺省。可以缺省。5

    33、.6.1宏汇编宏汇编5.6高级汇编语言技术(续)高级汇编语言技术(续)2宏调用宏调用经宏定义后的宏指令可以在源程序中调用,宏调用格式为:经宏定义后的宏指令可以在源程序中调用,宏调用格式为:宏指令名宏指令名实参,实参实参,实参宏调用只需要有宏指令名,若宏定义中有形参,那么宏调用时必须宏调用只需要有宏指令名,若宏定义中有形参,那么宏调用时必须带有实际参数来替代形参,实际参数的个数,顺序,类型与形参一一带有实际参数来替代形参,实际参数的个数,顺序,类型与形参一一对应,各个实参之间用逗号分开对应,各个实参之间用逗号分开。原则上实参的个数与形参的个数相。原则上实参的个数与形参的个数相等,但汇编程序不要求

    34、它们必须相等,若实参等,但汇编程序不要求它们必须相等,若实参个数大于形参个数,则个数大于形参个数,则多余的实参不予考虑,若实参个数小于形参个数,则多余的形参作多余的实参不予考虑,若实参个数小于形参个数,则多余的形参作“空空”处理。处理。5.6.1宏汇编宏汇编5.6高级汇编语言技术(续)高级汇编语言技术(续)3宏展开宏展开汇编程序在对源程序汇编时,对每个宏调用作宏展开汇编程序在对源程序汇编时,对每个宏调用作宏展开,每每条插入的宏体指令前带上加号条插入的宏体指令前带上加号“+”。例例5.11:不带参数的宏定义,用宏指令来实现回车换行。不带参数的宏定义,用宏指令来实现回车换行。宏定义:宏定义:CRL

    35、FMACROMOVDL,0DH;回车回车MOVAH,2INT21HMOVDL,0AH;换行换行MOVAH,25.6.1宏汇编(续)宏汇编(续)INT21HENDM宏调用:宏调用:CRLF宏展开:将下述程序段替换宏调用语句。宏展开:将下述程序段替换宏调用语句。MOV DL,0DH;回车回车MOV AH,2INT21HMOV DL,0AH;换行换行MOV AH,2INT21H5.6.1宏汇编(续)宏汇编(续)宏定义中的参数可以有多个,实参可以是数字,寄存器或宏定义中的参数可以有多个,实参可以是数字,寄存器或操作码。宏定义还可用部分操作码作参数,但在宏定义中必须操作码。宏定义还可用部分操作码作参数,

    36、但在宏定义中必须用用“&”作分隔符,作分隔符,&是一个操作符,它是一个操作符,它在宏定义体中可作为在宏定义体中可作为哑元的前缀,宏展开时,可以把哑元的前缀,宏展开时,可以把&前后两个符号合并成一个符前后两个符号合并成一个符号。号。例例5.12:宏定义带一个参数,用宏指令实现将:宏定义带一个参数,用宏指令实现将AX中内容右移任意次(小中内容右移任意次(小于于256)。宏定义:宏定义:SHIFTMACRONMOVCL,NSALAX,CLENDM宏调用宏调用1:SHIFT45.6.1宏汇编(续)宏汇编(续)4.宏调用中参数传递宏调用中参数传递宏调用宏调用2:SHIFT8宏展开宏展开1:MOVCL,4

    37、;AX中内容算术左移中内容算术左移4次次SALAX,CL宏展开宏展开2:MOVCL,8;AX中内容算术左移中内容算术左移8次次SALAX,CL5.宏定义嵌套宏定义嵌套在宏定义中允许使用宏调用,但必须先定义后调用。在宏定义中允许使用宏调用,但必须先定义后调用。例例5.14:宏定义:宏定义:AD1MACROM,NMOVBX,M5.6.1宏汇编(续)宏汇编(续)ADDAX,NENDMAD1MMACROR1,R2,R3PUSHAXPUSHBXAD1R1,R2MOVX3,AXPOPBXPOPAXENDM宏调用:宏调用:AD1MCX,BX,DX宏展开:宏展开:PUSHAX5.6.1宏汇编(续)宏汇编(续)

    38、PUSHBXAD1R1,R2;此语句不占内存;此语句不占内存MOVBX,CX;AD1宏定义展开宏定义展开ADDAX,BXMOVDX,AXPOPBXPOPAX5.6.1宏汇编(续)宏汇编(续)5.6.1宏汇编(续)宏汇编(续)格式为:格式为:PURGE宏指令名,宏指令名宏指令名,宏指令名PURGE:伪指令助记符,不可缺省,因为经过定义:伪指令助记符,不可缺省,因为经过定义的宏指令名,不允许重新定义,必须用的宏指令名,不允许重新定义,必须用PURGE语句语句将其取消后,才能重新定义,此语句一次可以取消将其取消后,才能重新定义,此语句一次可以取消多个宏指令名。多个宏指令名。6.取消宏定义语句取消宏定

    39、义语句5.6.1宏汇编(续)宏汇编(续)7.7.宏指令与子程序的区别宏指令与子程序的区别过程调用使用过程调用使用CALLCALL语句,由语句,由CPUCPU执行,宏指令调用由执行,宏指令调用由宏汇编程序宏汇编程序MASMMASM中宏处理程序来识别。中宏处理程序来识别。过程调用时,每调用一次都要保留程序的断点和保过程调用时,每调用一次都要保留程序的断点和保护现场,返回时要恢复现场和恢复护现场,返回时要恢复现场和恢复断点,增加了操作断点,增加了操作时间,执行速度慢。而宏指令调用时,不需要这些入时间,执行速度慢。而宏指令调用时,不需要这些入栈及出栈操作,执行速度较快。栈及出栈操作,执行速度较快。一个

    40、子程序设计,一般完成某一个功能,多次调用一个子程序设计,一般完成某一个功能,多次调用完成相同操作,仅入口参数可以改变,而宏指令可以完成相同操作,仅入口参数可以改变,而宏指令可以带哑元,调用时可以用实元取代,使不同的调用完成带哑元,调用时可以用实元取代,使不同的调用完成不同的操作,增加使用的灵活性。不同的操作,增加使用的灵活性。过程调用的子程序与主程序分开独立存在,经汇过程调用的子程序与主程序分开独立存在,经汇编后在存储器中只占有一个子程序段的空间,主程编后在存储器中只占有一个子程序段的空间,主程序转入此处运行,因此目标代码长度短,节省内存序转入此处运行,因此目标代码长度短,节省内存空间。而宏调

    41、用是在汇编过程中展开,宏调用多少空间。而宏调用是在汇编过程中展开,宏调用多少次,就插入多少次,因此目标代码长度大次,就插入多少次,因此目标代码长度大,占内存,占内存空间多;空间多;7.7.宏指令与子程序的区别宏指令与子程序的区别5.6.1宏汇编(续)宏汇编(续)1定重复定重复格式:格式:REPT表达式表达式宏体宏体ENDM其中,其中,REPTENDM:伪指令助记符,必须成对出现,不:伪指令助记符,必须成对出现,不可省略。宏体:表示需要重复的语句序列可省略。宏体:表示需要重复的语句序列。表达式:表示重。表达式:表示重复次数。复次数。5.6.2重复汇编重复汇编重复汇编伪指令语句有以下三种:重复汇编

    42、伪指令语句有以下三种:5.6高级汇编语言技术(续)高级汇编语言技术(续)例例5.16:将将2、4、8、16、32分配给连续的分配给连续的5个存储单元。个存储单元。NUM=1REPT5NUM=NUM*2DBNUMENDM汇编后汇编后:DB2DB4DB8DB16DB325.6.2重复汇编重复汇编5.6高级汇编语言技术(续)高级汇编语言技术(续)格式:格式:IRP形参,实参表形参,实参表宏体宏体ENDM其中,其中,IRPENDM:伪指令助记符,必须成对出现,不可省略。:伪指令助记符,必须成对出现,不可省略。宏体:要重复的宏体:要重复的语句序列,重复次数由参数个数决定。实数表中语句序列,重复次数由参数

    43、个数决定。实数表中是每次重复时将要取的实参,实参之间用逗号隔开,实参表用尖是每次重复时将要取的实参,实参之间用逗号隔开,实参表用尖括号括起来。每次重复,依次取实参表中一项,代入语句序括号括起来。每次重复,依次取实参表中一项,代入语句序列中哑元。前面将列中哑元。前面将2、4、8、16、32分配给分配给连续的连续的5个存储单元的个存储单元的例子也可以用如下不定重复伪指令:例子也可以用如下不定重复伪指令:IRPNUM,2,4,8,16,32DBNUMENDM2不定重复不定重复5.6.2重复汇编(续)重复汇编(续)例例5.17:若要把若要把AX,BX,CX,DX的内容压入堆栈,则可以用的内容压入堆栈,

    44、则可以用如下不定重复伪指令:如下不定重复伪指令:IRPREG,AX,BX,CX,DXPUSHREGENDM汇编后展开为以下四汇编后展开为以下四条指令:条指令:PUSH AXPUSH BXPUSH CXPUSH DX5.6.2重复汇编(续)重复汇编(续)格式为:格式为:IRPC 形式参数,字符串形式参数,字符串宏体宏体ENDM其中,其中,IRPC.ENDM:伪指令助记符,必须成对出现,不可省略。:伪指令助记符,必须成对出现,不可省略。宏体:重复宏体:重复执行的语句序列,每次重复时依次用字符串中字符代替执行的语句序列,每次重复时依次用字符串中字符代替形式参数,重复次数取决于字符串中形式参数,重复次

    45、数取决于字符串中字符的个数。字符串:可用尖字符的个数。字符串:可用尖括号也可不用尖括号括起来。括号也可不用尖括号括起来。5.6.2重复汇编(续)重复汇编(续)3不定重复字符不定重复字符汇编后展开为以下四条指令:汇编后展开为以下四条指令:POPDXPOPCXPOPBXPOPAX例例5.18:若要从堆栈中弹出若要从堆栈中弹出4个字,分别送入个字,分别送入DX,CX,BX,AX,则可用如下不定重复字符伪指令:则可用如下不定重复字符伪指令:IRPCREG,POPREG&XENDM3不定重复字符不定重复字符5.6.2重复汇编(续)重复汇编(续)条件汇编是对给定的条件进行测试,汇编程序根据测试结果,条件汇

    46、编是对给定的条件进行测试,汇编程序根据测试结果,将一段程序嵌入源程序汇编或不进行汇编,它的一般格式为:将一段程序嵌入源程序汇编或不进行汇编,它的一般格式为:IF表达式表达式指令体指令体1;条件为真汇编指令体;条件为真汇编指令体1ELSE指令体指令体2;条件为假汇编指令体;条件为假汇编指令体2ENDIF5.6.3条件汇编条件汇编5.6高级汇编语言技术(续)高级汇编语言技术(续)其中,其中,IFENDIF:条件汇编伪指令助记符,:条件汇编伪指令助记符,必须成对出现,不可省略。必须成对出现,不可省略。IF语句后的语句后的“”是指是指定的条件。如果定的条件。如果“IF”指定的条件为真时则宏汇指定的条件

    47、为真时则宏汇编程序将指令体编程序将指令体1中的中的语句汇编成相应的目标代码,语句汇编成相应的目标代码,否则就把指令体否则就把指令体2中的语句汇编成相应的目标代码。中的语句汇编成相应的目标代码。ELSE:是任选部分,如果没有:是任选部分,如果没有ELSE,那么,那么“IF”指定的条件满足就汇编,否则就不汇编。指定的条件满足就汇编,否则就不汇编。5.6高级汇编语言技术(续)高级汇编语言技术(续)5.6.3条件汇编条件汇编伪指令汇编条件IF 表达式表达式的值不等于0,条件满足IFE 表达式表达式的值等于0,条件满足IFDEF 符号符号已定义或被说明为外部符号E X T R NIFNDEF 符号符号未

    48、定义或未被说明为外部符号E X T R NIFB 变量为空,条件满足IFNB 变量不为空,条件满足IFIDN ,字符串1 和字符 串2 相同,条件满足IFDIF ,字符串1 和字符 串2 不相同,条件满 足“IF”条件汇编的形式见条件汇编的形式见表表5.1所示:所示:5.6.3条件汇编条件汇编例例5.20:利用条件汇编伪指令,可以根据不同情况,产生无条件利用条件汇编伪指令,可以根据不同情况,产生无条件转移指令如转移指令如JMP,或产生条件转移指令如,或产生条件转移指令如JE、JNE、JB、JNB等。等。宏定义:宏定义:GOTOMACROLOP,X,REL,YIFBRELJMPLOPELSEMO

    49、VAL,XCMPAL,YJ&REL LOPENDIFENDM5.6.3条件汇编条件汇编宏调用:宏调用:GOTOLOP1,VAR1,E,VAR2GOTOEXIT1宏展开:宏展开:MOV AL,VAR1CMP AL,VAR2JELOP1JMPEXIT15.6.3条件汇编条件汇编为了了解程序运行过程中的情况,应设法将运算结果显示到显示为了了解程序运行过程中的情况,应设法将运算结果显示到显示器上,最简单的方法就是调用操作系统的器上,最简单的方法就是调用操作系统的I/O子程序,我们称为子程序,我们称为DOS功能功能调用。调用。DOS为程序设计人员提供了许多可直接调用的功能为程序设计人员提供了许多可直接调

    50、用的功能子程序。调用时需要使用软中断指令:子程序。调用时需要使用软中断指令:INTn其中:其中:n为中断调用类型号,其值为为中断调用类型号,其值为00FFH。在使用。在使用INT指令前,指令前,应将调用的功能号送入应将调用的功能号送入AH,有关入口参量送入指定寄存器中。若,有关入口参量送入指定寄存器中。若有出口参量,中断调用返回后,有出口参量,中断调用返回后,结果在指定的寄存器或存储单元中。结果在指定的寄存器或存储单元中。DOS功能子程序的调用使用软中断指令功能子程序的调用使用软中断指令“INT21H”。DOS共有共有84个功能子程序。这些子程序的主要功能是:磁盘的读写控制、文件个功能子程序。

    展开阅读全文
    提示  163文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
    关于本文
    本文标题:第5章80868088汇编语言程序设计课件.ppt
    链接地址:https://www.163wenku.com/p-3861250.html

    Copyright@ 2017-2037 Www.163WenKu.Com  网站版权所有  |  资源地图   
    IPC备案号:蜀ICP备2021032737号  | 川公网安备 51099002000191号


    侵权投诉QQ:3464097650  资料上传QQ:3464097650
       


    【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。

    163文库