尾递归优化
创始人
2024-06-01 23:03:51

文章目录

  • 1. 前言
  • 2. 什么尾调用(Tail Call)?
  • 3. 尾调用优化
  • 4. Linux内核下的尾递归优化使用
  • 5. 参考资料

1. 前言

限于作者能力水平,本文可能存在谬误,对此给读者带来的损失,作者不错任何承诺。

2. 什么尾调用(Tail Call)?

如果对函数B的调用是函数A执行的最后一条语句,这就是尾调用(Tail Call)。详见 https://eklitzke.org/how-tail-call-optimization-works 或 https://www.ruanyifeng.com/blog/2015/04/tail-call.html 。

3. 尾调用优化

调用函数时会为其在堆栈上维护一个栈帧,记录局部变量和返回地址等信息,如果函数A对B的调用是函数A执行的最后一条语句,则表明函数A栈帧信息不会再被用到,这时可以将A的栈帧空间给函数B使用,而不是为B函数重新开辟栈帧空间,这就是尾递归优化(Tail Call Optimization)。详见 https://eklitzke.org/how-tail-call-optimization-works 或 https://www.ruanyifeng.com/blog/2015/04/tail-call.html 。

4. Linux内核下的尾递归优化使用

改变内核代码,通过脚本 scripts/bloat-o-meter 比较前后两次编译出的 vmlinux 文件中符号的增减变化:

./scripts/bloat-o-meter vmlinux.old vmlinux

5. 参考资料

https://eklitzke.org/how-tail-call-optimization-works
https://www.ruanyifeng.com/blog/2015/04/tail-call.html
https://www.cnblogs.com/arnoldlu/p/10442099.html

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...