微型计算机原理 第5章 80868088汇编语言程序设计ppt课件.ppt

微型计算机原理 第5章 80868088汇编语言程序设计ppt课件.ppt

ID:58793284

大小:3.34 MB

页数:69页

时间:2020-10-03

微型计算机原理  第5章 80868088汇编语言程序设计ppt课件.ppt_第1页
微型计算机原理  第5章 80868088汇编语言程序设计ppt课件.ppt_第2页
微型计算机原理  第5章 80868088汇编语言程序设计ppt课件.ppt_第3页
微型计算机原理  第5章 80868088汇编语言程序设计ppt课件.ppt_第4页
微型计算机原理  第5章 80868088汇编语言程序设计ppt课件.ppt_第5页
资源描述:

《微型计算机原理 第5章 80868088汇编语言程序设计ppt课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第5章8086/8088汇编语言程序设计§5.1汇编语言源程序的框架结构编制汇编语言源程序时,首先要使用段定义伪指令和段寻址伪指令来建立一个源程序的基本框架,而各段内容是由若干指令和数据组成的,这就形成了源程序。段名、过程名、符号名、标号都是编程人自己定义的,定义的原则是不超过规定长度,不使用保留字(即不与指令助记符、寄存器名等相重)。代码段中还可以定义过程(相当于子程序)和中断服务程序(以标号开始,以返回指令结束)。整个源程序必须以END伪指令结束,END后面还应带上第一条可执行指令的标号。一个最完整的源程序符号赋值等伪指令段名SEGM

2、ENT定义数据段……段名ENDS段名SEGMENT定义堆栈段……段名ENDS段名SEGMENT定义附加段……段名ENDS段名SEGMENTASSUME语句……过程名PROC(NEAR/FAR)保存信息(或称保护现场)定义代码段……恢复信息(或称恢复现场)RET过程名ENDP……段名ENDSEND标号源程序框架:根据具体格式确定是否使用该标号第二种格式:段名SEGMENTASSUME语句过程名PROCFAR起始标号:返回DOS地址入栈……RET过程名ENDP段名ENDSEND起始标号第一种格式:段名SEGMENTASSUME语句起始标号:段

3、寄存器赋值等语句……(程序主体)MOVAH,4CHINT21H段名ENDSEND起始标号代码段框架结构有如下两种格式:区别:两种格式的本质区别在于返回DOS的方法不同:对于第一种格式,采用了调用DOS系统的4CH功能,返回DOS。对于第二种格式,DOS返回方法是调用20H类型的中断服务程序。顺序程序结构是指完全按照顺序逐条执行的指令序列,不产生分支。如图5.1所示。图5.1顺序程序的结构形式§5.2顺序结构程序设计例5.1:试分别用汇编语言源程序的两种框架结构编制程序,求出表达式:(X×4-Y)/2的值,并保存到Z存储单元中,其中X,Y均

4、为字节变量(假设乘积的高8位为0)。解:流程图图5.2例5.1的功能实现流程图参考程序1:第一种格式DATASEGMENT;定义数据段XDB2YDB4ZDB?;定义变量DATAENDSSTACKSEGMENTPARASTACK;定义堆栈段DW20HDUP(0)STACKENDSCODESEGMENT;定义代码段ASSUMECS:CODE,DS:DATA,SS:STACKBEGIN:MOVAX,DATAMOVDS,AX;DS赋初值MOVAL,X;AL←XMOVCL,2;设置移位次数SALAL,CL;AL←X×4SUBAL,Y;AL←X×4-

5、YSARAL,1;AL←(X×4-Y)/2MOVZ,AL;存结果MOVAH,4CH;返回DOSINT21HCODEENDS;代码段结束ENDBEGIN;源程序结束参考程序2:第二种格式DATASEGMENT;定义数据段XDB2YDB4ZDB?DATAENDSSTACKSEGMENTPARASTACK;定义堆栈段DW20HDUP(0)STACKENDSCODESEGMENT;定义代码段ASSUMECS:CODE,DS:DATA,SS:STACKPROC1PROCFAR;使RET为远返回BEGIN:PUSHDS;入栈保存地址MOVAX,0;程

6、序段前缀的首地址PUSHAXMOVAX,DATAMOVDS,AXMOVAL,X;AL←XMOVCL,2SALAL,CL;AL←X×4SUBAL,Y;AL←X×4-YSARAL,1;AL←(X×4-Y)/2MOVZ,AL;存结果RET;取程序段前缀首地址PROC1ENDPCODEENDSENDBEGIN§5.3分支结构程序设计分支程序结构可以有两种形式,如图所示,分别相当于高级语言程序中的IF-THEN-ELSE语句和CASE语句,它们适用于根据不同条件做不同处理的情况。§5.3.1用比较/测试的方法实现IF-THEN-ELSE结构实现方法

7、:在产生分支之前,通常用比较、测试的办法在标志寄存器中设置相应的标志位,然后再选用适当的条件转移指令,以实现不同情况的分支转移。(1)使用比较指令CMPdest,src该指令进行减法操作,但不保存结果,只设置标志位。(2)使用测试指令TESTdest,src该指令进行逻辑“与”操作,但不保存结果,只设置标志位。见130页例5.3§5.3.2用地址表法实现CASE结构(即多路分支)基本思路:将各分支程序的入口地址依次存储形成一个地址表,让BX指向地址表的首地址,从键盘接收或其他方式获取要转到的分支号,再让BX与分支号进行运算,使BX指向对应

8、分支入口地址,最后即可使用JMPWORDPTR[BX]或JMPDWORDPTR[BX]指令实现所要转到的分支。图5.6用地址表法实现多路分支的结构框图例5.4:编程实现菜单选择,根据不同选择做

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。