关于 Tail Calls Optimization

本文介绍了尾调用优化(Tail Calls Optimization, TCO)的概念及其在编译器中的实现方式。通过具体的代码示例,展示了如何利用TCO来减少栈空间的使用,提高程序效率。并比较了不同编译器在处理递归函数时的表现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于Tail Calls Optimization,中文资料不是很多。但这也不是很难的概念。

所谓Tail Call,就是指一个函数返回的值,为另一个函数的返回值。例子如下

 

foo()中调用函数bar()产生的栈空间是多余,所以支持Tail Call Optimization的编译器都能优化此过程,消除多余的栈操作。

 

关于算 factorial ,代码如下:

严格意义上来说,并不是tail call,但是GCC竟然能神奇地将它优化成一个递推式!而VC,ICC,pgcpp都不能做到这样的优化。

 

看来确实是,不同编译器有自己的强项。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值