Pengoptimuman rekursi ekor dalam .NET/C#
Rekursi ekor bermakna tindakan terakhir fungsi ialah memanggil dirinya sendiri dengan set parameter baharu. Dalam banyak bahasa pengaturcaraan, rekursi ekor dioptimumkan secara automatik untuk mengelak daripada mencipta bingkai tindanan baharu untuk setiap panggilan rekursif. Walau bagaimanapun, dalam versi semasa Rangka Kerja .NET, pengoptimuman ini tidak dilaksanakan dalam C#.
Salah satu sebab ialah kerumitan kompilasi JIT. Mengoptimumkan rekursi ekor memerlukan JIT melakukan analisis mendalam untuk memastikan kelakuan fungsi kekal tidak berubah selepas pengoptimuman. Selain itu, kompilasi NGen (Penjana Imej Asli) tidak direka bentuk untuk menjadikan pengoptimumannya lebih agresif, mungkin untuk mengelak daripada memperkenalkan pepijat yang mungkin berbeza-beza bergantung pada kaedah kompilasi yang digunakan.
CLR (Common Language Runtime) menyokong pengoptimuman panggilan ekor, tetapi pengkompil bahasa mesti menjana opcode yang sepadan dan JIT mesti bersedia untuk menghormatinya. Walaupun pengkompil F# menjana opcode yang diperlukan, pengkompil C# pada masa ini tidak.
Walaupun pada masa ini .NET/C# tidak menyokong pengoptimuman rekursif ekor dalam JIT, corak rekursif ekor tertentu boleh dioptimumkan secara manual menggunakan buka gelung atau monad keadaan.
Atas ialah kandungan terperinci Adakah .NET/C# Menyokong Pengoptimuman Rekursi Panggilan Ekor?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!