C#编译与尾递归优化?

基于丰富的堆栈溢出,我已经得到了关于尾部递归优化是否完成特定c#代码的答案.一些问题似乎在谈论

>正在发布的.net的较新版本中推测优化
>构建应用程序作为x64bit应用程序来实现优化
>从Visual Studio中的调试版本切换到发行版,以实现优化
>根本没有优化,微软社区声称他们不会对“安全问题”进行尾递归优化(并没有真正理解这一点)
>随机发生

所以就C#4.0(Visual Studio 2013/2015)而言,如果能够保证尾部的递归优化,那么如何呢?

解决方法

有不同的级别可以支持尾呼叫优化. JIT对于发生的很多优化负有真正的责任. C#编译器本身甚至没有进行方法内联,也就是JIT编译器的责任. C#编译器可以使用 Tailcall IL opcode指定一个调用作为尾部调用,但是我相信没有版本的C#编译器这样做. JIT编译器只要符合要求,就可以进行尾调用优化.特别是,我相信只有64位的JIT才能做到这一点.这个 blog post概述了JIT64不能使用尾调优化的一些场景.我确信标准可能会发生变化,因为他们正在重新编写代号为RyuJIT的JIT编译器.

如果您想要一个可以使用TCO的程序的简短示例,请尝试:

class Program
{
    static void Main(string[] args)
    {
        Test(1);
    }

    private static void Test(int i)
    {
        Console.WriteLine(i);
        Test(i + 1);
    }
}

设置项目以构建Release / x64(或Anycpu不喜欢32位),并启动,而不附加调试器.该程序将永远运行.如果我不做所有这些事情,那么在20947左右就会得到一个stackoverflow异常.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...