调用递归过程或函数时,处理参数及返回地址为什么要用栈来实现?

问:调用递归过程或函数时,处理参数及返回地址需要用一种称为(  )的数据结构。

答:栈

 


一个函数的运行期间调用另一个函数时,在运行被调用函数之前,系统需要先完成3个操作:① 将所有的实参、返回地址等信息传递给被调函数保存;
② 为被调函数的局部变量分配存储区;
③ 将控制转移到被调函数的入口。

从被调函数返回调用函数之前,系统还要完成3个操作:
① 即保存被调函数的计算结果;
② 释放被调函数的数据区;
③ 依照被调函数保存的地址将控制转移到调用函数。

有多个函数构成嵌套调用时,按照"后调用先返回"的原则,上述函数之间的信息传递和控制转移必须通过""来实现,每当调用一个函数时,就在栈顶为它分配一个存储区,每当退出一个函数时,就释放它的存储区,当前正在运行的函数的数据区必在栈顶。递归函数的运行过程类似于多个函数的嵌套调用,只是调用和被调用函数是同一个函数。

  • 8
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值