单片机原理与应用设计 子程序结构PPT.pptVIP

单片机原理与应用设计 子程序结构PPT.ppt

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
单片机原理与应用设计 子程序结构PPT

第6章 子程序结构 介绍 P139 子程序又叫过程,相当与高级语言的过程和函数。 子程序结构是模块化程序设计的基础。 结构: procname PROC Attribute ….. procname ENDP Attribute为 NEAR(段内调用) FAR(段间调用) 一.子程序的设计方法 1.子程序的调用和返回 P140 call 格式:CALL 目标地址 功能:暂停正在执行的程序,转去执行相应的子程序,目标地址给出调用于程序的入口地址。 在子程序执行完后,由子程序中的RET指令返回至CALL指令的下一条指令继续执行。为此,CALL指令同时需要把断点地址(即CALL指令的下—条指令的CS和IP)入栈保护 CALL指令不影响标志位,但应特别注意在于程序中对相关寄存器的保护。 CALL指令实质上是一条特殊的、带返回的无条件转移指令。 CALL指令目标地址的形成方式与JMP指令完全类似,即有段内直接调用、段内间接调用、段间直接调用与段间间接调用四种方式。直接调用其目标地址直接出现在CALL指令中,间接调用其目标地址存放在指令所指向的寄存器或内存单元中。 (1)段内直接接调用 格式:CALL NEAR PTR 标号 功能:首先将断点的IP值压入推栈,再将从指令中得到的子程序相对偏移量加到IP,然后根据IP转相应子程序执行。 如: CALL OUTPUT ;段内直接调用子程序output (2)段内间接调用 格式:CALL REG|MEM 功能:首先将断点的IP值压入堆栈,再将子程序的地址偏移量送入IP,然后根据IP转相应子程序执行。子程序的地址偏移量为指令中指定的16位通用寄存器或存储单元值。 如: CALL BX CALL WORD PTR [BX] (3)段间直接调用 格式:CALL FAR PTR 标号 功能:首先把断点的CS值压入堆栈,并将于程序的段地址送入CS再把断点的IP值压入堆栈,把子程序的地址偏移量送入IP。然后根据CS:IP转相应于程序执行。 如: CALL FAR PTR OUTPUT ;段间直接调用子程序OUTPUT (4)段间间接调用 格式:CALL DWORD PTR MEM 功能:首先把断点的CS压入堆栈,并将指令中指定的双字存储器的第二个字的内容送入CS;再把断点的IP压入堆栈,再将双字指针的第一个字的内容送入IP。然后根据CS:IP转相应子程序执行。 如: CALL DWORD PTR [BX] CALL DWROD PTR MEM32 2.返回指令RET P141 返回指令RET通常作为一个子程序的最后一条指令,用以返回到调用这个于程序的主程序断点处继续执行。与调用指令相对应,返回指令RET也有段内返回与段间返回两种形式。是段内返回,还是段间返回,汇编程序能自动确定,并形成相应的返回指令。返回指令有两种格式: 格式一:RET 格式一为不带偏移量的返回。 若是段内的RET指令(机器码为C3H/C2H),只返回主程序断点处的IP值。即从堆栈弹出一个字送入IP,且SP加2。然后返回CS:IP处继续执行程序。此时的返回也称近返回。 若为段间的RET指令(机器码为CBH/CAH),则要返回主程序断点处的段地址和IP值。将从堆栈弹出一个字送CS, SP+2→SP,再从堆栈弹出一个字送Cs,同时SP加2。然后返回CS:IP处继续执行程序。此时RET也称远返回。 格式二:RET n 格式二为带偏移量的返回,与格式一完全类似,只是在修改堆栈指针时需增加SP←SP+n处理。n一般为偶数,格式二适合主程序向于程序利用堆栈传递参数的情况。在利用堆栈传递参数时,主程序先将参数压入堆栈,在于程序中将参数取出,为找到正确的返回地址,保持堆栈平衡,应将堆栈指针修正。 返回指令RET对标志位无影响。 例7-3 求两个数的最大公约数 P144 用展转相除法 在我们编程中用的最多方法就是展转相除法了,展转相除法是古希腊求两个正整数的最大公约数的也叫欧几里德算法,用较大的数除以较小的数,结果的余数和被除数构成新的一对数,继续做上面的除法,直到大数被小数求尽 。 GYS PROC PUSH AX PUSH BX PUSH DX G1: XOR DX,DX DIV BX CMP DX,0 JZ EXIT MOV AX,BX MOV B

文档评论(0)

zhuliyan1314 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档