Makro Rekursif dalam C/C : Mitos atau Realiti?
Walaupun tiada makro rekursif langsung dalam C/C , penyelesaian yang bijak wujud untuk mencapai rupa kefungsian rekursif.
Rekursif Emulasi Makro Menggunakan Ungkapan Tertunda dan Arahan
Satu pendekatan melibatkan penggunaan ungkapan tertunda dan tidak arah. Dengan menggunakan makro DEFER dan EMPTY, kami boleh menangguhkan penilaian makro kami dan menghalangnya daripada dicat biru oleh prapemproses. Ini mengelakkan had pengembangan rekursif.
Sebagai contoh, pertimbangkan makro berikut:
#define pr_id() pr #define pr(n) ((n==1)? 1 : DEFER(pr_id)()(n-1))
Dengan memanfaatkan makro ini, kami memperoleh keupayaan untuk memanggil pr(n) secara rekursif secara bulatan . Walau bagaimanapun, teknik ini memerlukan berbilang imbasan prapemproses untuk pengembangan lengkap.
Makro Rekursif melalui Penilaian Ungkapan
Kaedah lain melibatkan penggunaan siri makro penilaian ekspresi, seperti EVAL1 hingga EVAL5, untuk mensimulasikan tingkah laku rekursif.
Sebagai contoh, untuk menentukan makro ulangan rekursif, kita boleh menggunakan sintaks berikut:
#define REPEAT(count, macro, ...) \ WHEN(count) \ ( \ OBSTRUCT(REPEAT_INDIRECT) () \ ( \ DEC(count), macro, __VA_ARGS__ \ ) \ OBSTRUCT(macro) \ ( \ DEC(count), __VA_ARGS__ \ ) \ )
Dengan menggunakan berbilang pengembangan, kita boleh mencapai gelagat seperti rekursif, seperti yang ditunjukkan oleh kod berikut:
EVAL(REPEAT(8, M, ~)) // Output: 0 1 2 3 4 5 6 7
Pelaksanaan Kod Isu
Kod yang dinyatakan dalam soalan anda tidak akan dilaksanakan kerana penggunaan yang tidak betul daripada objek cout. Sintaks yang betul hendaklah:
cout << "result: " << pr(5) << endl;
Ganti < dan > simbol dengan << untuk membolehkan output yang betul dalam C .
Atas ialah kandungan terperinci Bolehkah Makro Rekursif Dicapai dalam C/C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!