- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
六、实验结论:
七、指导教师
您可能关注的文档
最近下载
- NB∕T 47010-2017 承压设备用不锈钢和耐热钢锻件(高清版).pdf VIP
- 车辆风险预警方法、路侧控制单元及风险预警控制系统.pdf VIP
- 2025年版《中文核心期刊要目总览》.docx VIP
- 密码学基础-密码学.ppt VIP
- 中国国家标准 GB/T 4706.1-2024家用和类似用途电器的安全 第1部分:通用要求.pdf
- 灯具安装技术交底1.docx VIP
- 乙烯三机:发展与未来.pptx VIP
- NB/T 47008-2017 承压设备用碳素钢和合金钢锻件.pdf VIP
- 密钥管理与密钥分配现代密码学.ppt VIP
- 初中信息技术校本课程《遨游3D世界,利用三维设计软件制作创意作品》教案.doc VIP
文档评论(0)