函数:尾递归优化

本文探讨了尾递归优化的概念,并通过C语言和Go语言的例子对比,解释了为什么Go的编译器不进行尾递归优化。主要原因是Go的栈帧处理方式和对并发的考虑,以及如何通过抢占机制保持多任务公平性。GCC则更倾向于性能优化,利用寄存器避免栈帧分配。
摘要由CSDN通过智能技术生成

什么是尾递归优化

我们看 C 语言的一个例子:

#include <stdio.h>
#include <stdlib.h>

int sum(int x)
{
    if (x == 0) return 0;
    return x + sum(x - 1);
}

int tailsum(int x, int total)
{
    if (x == 0) return total;
    return tailsum(x - 1, total + x);
}

int main()
{
    int y = sum(5);
    printf("%d\n", y);

    int z = tailsum(5, 0);
    printf("%d\n", z);
}

简单的统计函数,sum 是递归调用,tailsum 是尾调用。

$ gcc -g -O0 -o test tail.c #不优化编译
$ objdump -d -M -intel test | grep -A20 "<sum>:"

从返回的汇编注意到call <sum>就是很典型的递归调用,重复调用自己。这种状态下没有做任何优化。

$ gcc -g -O2 -o test tail.c #优化编译
$ objdump -d -M -intel test | gr
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值