C#은 효율적인 재귀 함수를 위한 꼬리 호출 최적화의 이점에도 불구하고 현재 이를 지원하지 않습니다.
문제는 실행 속도와 코드 최적화의 복잡성 사이의 균형에 있습니다. JIT(Just-In-Time) 컴파일은 광범위한 코드 분석보다 빠른 컴파일을 우선시합니다. CLR(공용 언어 런타임)은 tail-call 최적화를 지원할 수 있지만 C# 컴파일러는 필요한 opcode를 생성하지 않습니다.
다음 예를 고려해보세요.
<code class="language-csharp">private static void Foo(int i) { if (i == 1000000) return; if (i % 100 == 0) Console.WriteLine(i); Foo(i+1); }</code>
Visual Studio 2008조차도 이 재귀 함수를 루프로 최적화하지 못하며 이는 컴파일러 분석의 한계를 보여줍니다.
F#과 같은 언어는 마무리 호출 최적화를 위한 적절한 opcode를 생성하는 데 필요한 컴파일러 확장을 이미 구현했습니다. 이는 향후 C# 버전에 이 기능이 포함될 것임을 시사합니다. 그러나 NGen(네이티브 이미지 생성기) 컴파일의 보수적인 특성은 성능 회귀 방지를 우선시하므로 잠재적인 장애물로 남아 있습니다.
이 주제에 대해 더 자세히 알아보려면 참조 블로그 게시물을 참조하세요. tail-call 최적화 및 아키텍처 종속성과 관련된 버전 4.0의 CLR 변경 사항에 대한 자세한 정보를 제공합니다.
위 내용은 C#이 테일콜 재귀를 최적화하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!