§5.1汇编言源程序的框架结构.pptVIP

  • 0
  • 0
  • 约1.4万字
  • 约 69页
  • 2018-08-09 发布于浙江
  • 举报
§5.1汇编言源程序的框架结构

§5.1 汇编语言源程序的框架结构 ? 编制汇编语言源程序时,首先要使用段定义伪指令和段寻址伪指令来构造一个由若干指令和数据组成的程序。构造一个源程序的框架结构有如下两种格式: 第一种格式: …… MOV AH,4CH ;返回DOS INT 21H CODE ENDS END BEGIN;第二种格式: …… RET ;取程序段前缀首地址 MAIN ENDP CODE ENDS END BEGIN 区别:两种格式的本质区别在于返回DOS的方法不同: 对于第一种格式,采用了调用DOS系统的4CH功能,返回DOS。具体方法是:在要返回DOS处,安排如下两条指令: MOV AH,4CH INT 21H 对于第二格式,DOS返回方法是调用20H类型的中断服务程序。 ;§5.2 顺序结构程序设计 顺序程序结构是指完全按照顺序逐条执行的指令序列,这种结构的流程图除了有一个开始框和结束框外,就是若干处理框,没有判断框,如图5.1所示。 图5.1 顺序程序的结构形式 ;例5.1:试分别用汇编语言源程序的两种框架结构编制程序,求出表达式:(X×4-Y)/2的值,并保存到RESULT存储单元中,其中X,Y均为字节变量。;参考程序1: DATA SEGMENT ;数据段 X DB 2 Y DB 4 Z DB ? ;定义变量 DATA ENDS STACK SEGMENT PARA STACK DW 20H DUP(0) STACK ENDS CODE SEGMENT ;代码段 ASSUME CS:CODE,DS:DATA,SS:STACK ;BEGIN: MOV AX,DATA MOV DS,AX ;DS赋初值 MOV AL,X ;AL←X MOV CL,2 SAL AL,CL ;AL←X×4 SUB AL,Y ;AL←X×4-Y SAR AL,1 ;AL←(X×4-Y)/2 MOV Z,AL ;存结果 MOV AH,4CH ;返回DOS INT 21H CODE ENDS END BEGIN;参考程序2: DATA SEGMENT X DB 2 Y DB 4 Z DB ? DATA ENDS STACK SEGMENT PARA STACK DW 20H DUP(0) STACK ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK PROC1 PROC FAR ;使RET为远返回 END BEGIN;BEGIN: PUSH DS ;入栈保存地址 MOV AX,0 ;程序段前缀的首地址 PUSH AX MOV AX,DATA MOV DS,AX MOV AL,X ;AL←X MOV CL,2 SAL AL,CL ;AL←X×4 SUB AL,Y ;AL←X×4-Y SAR AL,1 ;AL←(X×4-Y)/2 MOV Z,AL ;存结果 RET ;取程序段前缀首地址 ;PROC1 ENDP CODE ENDS;§5.3.1 用比较/测试的方法实现IF-THEN-ELSE结构 实现方法:在产??分支之前,通常用比较、测试的办法在标志寄存器中设置相应的标志位,然后再选用适当的条件转移指令,以实现不同情况的分支转移。 (1)进行比较,使用比较指令: CMP DEST,SRC 该指令进行减法操作,而不保存结果,只设置标志位。 (2)进行测试,使用测试指令 TEST DEST,SRC 该指令进行逻辑与操作,而不保存结果,只设置标志位。;§5.3.2 用地址表法实现CASE结构(即多路分支) 用地址表法实现CASE结构的基本思路是:将各分支程序的入口地址依次罗列形成一个地址表,让BX指向地址表的首地址,从键盘接收或其他方式获取要转到的分支号,再让BX与分支号进行运算,使BX指向对应分支入口地址,最后即可使用JMP WORD PTR [BX] 或JMP DWORD PTR [BX] 指令实现所要转到的分支;程序设计流程图如图5.6所示:;图5.6 用地址表法实现多路分支的结构框图 ;参考程序: DATA SEGMENT MENU DB 0DH,0AH,0:Chinese! DB 0DH,0AH,1:English! DB 0DH,0AH,2: German! DB 0DH,0AH,Please choose one to answer the following question:$ ER DB 0DH,0AH,I am sorry,you choose the mistake!$;S0 DB 0DH,0AH,OK,Please

文档评论(0)

1亿VIP精品文档

相关文档