实验七 子程序设计.docVIP

  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文档。上传文档
查看更多
实验七子程序设计.doc实验七子程序设计.doc

实验 成绩 实验项目名称 实验七 子程序设计 实验目的与要求: 目的: 1.熟悉汇编语言程序设计结构; 2.熟悉汇编语言子程序设计方法; 3.熟悉利用汇编语言子程序参数传递方法; 具体要求: 1、掌握利用堆栈传递参数的子程序调用方法。 2、掌握子程序递归调用方法。 3、过程伪指令: PROC,ENDP,NEAR和FAR。 4、8088指令: CALL,RET,RET n。 5、利用RET指令退出EXE文件的方法。 二、实验设备及软件: Masm for Windows 集成实验环境 2015 三、实验方法(原理、流程图) 实验原理: 在MASM中粘贴代码,调试: 在汇编语言中,子程序的调用用CALL,返回用RET指令来完成。当发生CALL过程调用时,返回地址入栈;而运行RET指令时,则由栈顶取出返回地址。 CALL指令执行分两步走;第一步,保护返回地址,利用堆栈实现,即将返回的地址压入堆栈;第二步,转向子程序,即把子程序的首地址送入IP或CS:IP。 RET指令功能是返回主程序,即把子程序的返回地址送入IP或CS:IP。 .段内调用与返回:调用子程序指令与子程序同在一个段内。因此只修改IP; .段间调用与返回:调用子程序与子程序分别在不同的段,因此在返回时,需同时修改CS:IP。 四、实验过程、步骤及内容 实验内容及步骤: 一、利用堆栈传递参数的子程序调用。(求累加和) 程序: stack segment stack db 256 dup(0) stack ends data segment ary1 db 1,2,3,4,5,6,7,8,9,10 count1 equ $-ary1 sum1 dw ? ary2 db 10,11,12,13,14,15,16,17,18 count2 equ $-ary2 sum2 dw ? data ends main segment assume cs:main,ds:data,ss:stack start proc far mov ax,stack mov ss,ax mov ax,data mov ds,ax push ds mov ax,count1 push ax lea ax,ary1 push ax call far ptr sum push ds mov ax,count2 push ax lea ax,ary2 push ax call far ptr sum ret start endp main ends proce segment assume cs: proce sum proc far push bp mov bp,sp mov cx,[bp+8] mov bx,[bp+6] mov ax,[bp+10] mov ds,ax xor ax,ax adn: add al,[bx] adc ah,0 inc bx loop adn mov [bx],ax pop bp ret 6 sum endp proce ends end start 步骤: 1、输入,汇编并将此程序连接成EXE文件。 2、用DEBUG的断点命令和T命令运行此程序,观察并记录每次过程调用及进出 栈指令前后(带;的语句)的SP和堆栈内容。 3、记录最后结果:SUM1,SUM2的段及偏移地址和它们的内容。 二、子程序递归调用(求阶乘)。 程序: stack segment stack db 100h dup(?) stack ends data segment resul dw ? data ends code segment main proc far assume cs:code,ds:data,ss:stack start: mov ax,stack mov ss,ax mov ax,data mov ds,ax mov ax,5 call fact mov resul,ax ret fact proc and al,al jne iia mov al,1 ret iia: push ax dec al call fact x2: pop cx mul cl ret fact endp main endp code ends end start 步骤: 1、将程序输入,汇编并连接成EXE文件。 2、用DEBUG的断点和T命令检查并记录每层递归嵌套过程的堆栈和AL内容。 3、修改源程序,将阶乘数 3 改为本程序的最大允许值(是多少?),重新汇编连接之。用DEBUG运行并记录RESUL单元内容。 4、若要在DOS命令下直接运行并显示阶乘结果(16进制形式),试修改程序并调试运行 五、实验数据(现象)处理分析 实验结果: 1: 2 六、实验结论: 七、指导教师

文档评论(0)

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

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

1亿VIP精品文档

相关文档