汇编语言程序设计-分支结构

上传人:痛*** 文档编号:244429797 上传时间:2024-10-04 格式:PPT 页数:19 大小:1.70MB
返回 下载 相关 举报
汇编语言程序设计-分支结构_第1页
第1页 / 共19页
汇编语言程序设计-分支结构_第2页
第2页 / 共19页
汇编语言程序设计-分支结构_第3页
第3页 / 共19页
点击查看更多>>
资源描述
单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,单击此处编辑母版标题样式,程舒慧,2011.9.19,汇编语言,程舒慧,2011.11.15,5.2,分支程序设计,分支结构是对问题的处理方法有两种以上不同选择时采用的程序设计方法,在程序中,根据某一判断的不同结果执行不同的程序段。,根据执行的程序段数量的多少不同,可分为双分支结构程序和多分支结构程序。,每一次对条件的判断都会产生两种可能的结果:真(条件满足)或假(条件不满足)。,5.2,分支程序设计,1.,双分支结构,典型的双分支结构程序的流程图:,条件成立跳转执行第2个分支语句体,否则顺序执行第1个分支语句体。注意第1个分支体后一定要有一个JMP指令跳到第2个分支体后,5.2,分支程序设计,条件成立跳转,否则顺序执行分支语句体;注意选择正确的条件转移指令和转移目标地址,5.2,分支程序设计,2.,多分支程序设计,多个条件对应各自的分支语句体,哪个条件成立就转入相应分支体执行。多分支可以化解为双分支或单分支结构的组合,例如:,Xor,ah,ah,;,等效于,cmp,ah,0,jz,function0,;ah,0,,转向,function0,dec,ah,;,等效于,cmp,ah,1,jz,function1,;ah,1,,转向,function1,dec,ah,;,等效于,cmp,ah,2,jz,function2,;ah,2,,转向,function2,AH=0,function0,Y,N,AH=1,function1,Y,N,AH=2,function2,Y,N,5.2,分支程序设计,地址表形成多分支,利用地址表法实现多分支程序设计的一般方法为:,把各分支程序段的入口地址(一般是偏移地址,也,可以使段地址与偏移地址)依次存放在数据段的一,个表中,形成地址表。取各分支程序段的编号作为,给分支入口地址的表地址的位移量。,某个分支程序入口地址的表地址为:,表地址,=,编号*,2+,入口地址首地址,。,根据条件首先在地址表中找到转移的目标地址,然,后转到相应位置,从而实现多分支。,5.2,分支程序设计,例:用地址表法编写程序实现从低到高逐位检测一个字节数据,找到第一个非,0,的位数。检测时,为,0,,则继续检测;为,1,,则转移到对应的处理程序段显示相应的位数。,DATA SEGMENT,NUM DB 78H,ADTAB DW AD0,,,AD1,,,AD2,,,AD3,,,AD4,,,AD5,,,AD6,,,AD7,;地址表,DATA ENDS,CODE SEGMENT,ASSUME CS:CODE,,,DS:DATA,START:MOV AX,DATA,MOV DS,AX,5.2,分支程序设计,MOV AL,NUM,MOV DL,?,CMP AL,0,JZ DISP,MOV BX,0;BX,用来记录位,1,的位数,AGAIN:SHR AL,1,JC NEXT,INC BX,JMP AGAIN,NEXT:SHL BX,1,JMP ADTABBX,AD0:MOV DL,0,JMP DISP,AD1:MOV DL,1,JMP DISP,AD2:MOV DL,2,;第,2,位为,1,,,JMP DISP,AD3:MOV DL,3,JMP DISP,AD4:MOV DL,4,JMP DISP,AD5:MOV DL,5,JMP DISP,AD6:MOV DL,6,JMP DISP,AD7:MOV DL,7,DISP:MOV AH,2,;显示,INT 21H,MOV AH,4CH,;返回,DOS,INT 21H,CODE ENDS,END START,第,6,章 子程序结构,把功能相对独立的程序段单独编写和调试,作为一个相对独立的模块供程序使用,就形成子程序,子程序可以实现源程序的模块化,可简化源程序结构,可以提高编程效率,6.1,子程序的设计方法,6.1,子程序的设计方法,1.,过程定义伪操作,过程名,(子程序名)为符合语法的标识符,NEAR,属性(段内近调用)的过程只能被相同代码段的其他程序调用,主程序和子程序在同一代码段,FAR,属性(段间远调用)的过程可以被相同或不同代码段的程序调用,主程序和子程序不在同一代码段,过程名,PROC NEAR|FAR,.,过程名,ENDP,code segment,main proc far,call,subr1,ret,main,endp,subr1,proc,near,ret,subr1,endp,code ends,segx,segment,subt,proc,far,ret,subt,endp,call,subt,segx,ends,segy,segment,call,far,ptr,subt,segy,ends,6.1,子程序的设计方法,子程序调用方法说明,一个子程序可以供多个用户编写的主程序调用。在不了解子程序内部算法的前提下能够很好地使用子程序也是子程序应具备的特性。,一个完整的子程序,应包括子程序调用方法说明。主要包括以下,6,个方面内容。,(,1,)子程序名:供调用子程序时使用,(,2,)子程序功能:供选择子程序时参考,(,3,)占用寄存器:说明子程序执行时,要使用哪些寄存器;子程序执行完后,哪些寄存器的内容被改变,哪些寄存器的内容保持不变。,(,4,)入口参数:说明子程序执行应具备的条件。,(,5,)输出参数:说明子程序执行后的结果存放在何处。,(,6,)子程序调用示例:说明子程序的调用格式。,6.1,子程序的设计方法,子程序的调用与返回,子程序调用:隐含使用堆栈保存返回地址,call,near,ptr,subp,(1),保存返回地址,(2),转子程序,call,far,ptr,subp,(1),保存返回地址,(2),转子程序,子程序返回:,ret,(SP),(IP),(IP),(CS),(SP),6.1,子程序的设计方法,3.,保存与恢复寄存器,一般通过堆栈来实现,主要在子程序中进行,例如,子程序,subt,中用到了寄存器,ax,,,bx,,,cx,和,dx,,则可能的保存与恢复寄存器如左:,subt,proc far,push ax,push,bx,push,cx,push,dx,pop,dx,pop,cx,pop,bx,pop ax,ret,subt,endp,6.1,子程序的设计方法,4.,子程序的参数传送,入口参数,(输入参数):,主程序提供给子程序,出口参数,(输出参数):,子程序返回给主程序,参数的形式:,数据本身(传值),数据的地址(传址),传递的方法:,寄存器 变量 堆栈,6.1,子程序的设计方法,(,1,)通过寄存器传送参数,最常用的一种方式,但能传递的参数有限,适合于参数较少的情况。,需要注意:用于传递出口参数的寄存器不能进行现场保护和恢复。,6.1,子程序的设计方法,6.1,子程序的设计方法,6.1,子程序的设计方法,
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 管理文书 > 施工组织


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!