Koma dalam C/C Macros: Meluaskan Keupayaan
Pernyataan Masalah:
Pertimbangkan makro ditakrifkan seperti berikut:
#define FOO(type, name) type name
Makro ini memberikan taip dan nama kepada pembolehubah. Walau bagaimanapun, kerumitan timbul apabila menggunakan struktur data kompleks dalam makro, seperti yang ditunjukkan di bawah:
FOO(std::map<int, int>, map_var); // Error: Excess arguments passed to macro
Penyelesaian:
Satu penyelesaian melibatkan penentuan alias jenis untuk memudahkan ungkapan:
typedef std::map<int, int> map_int_int_t; FOO(map_int_int_t, map_var); // Valid
Makro Dipertingkat Sintaks:
Walau bagaimanapun, terdapat penyelesaian yang lebih cekap dan ergonomik: mentakrifkan makro COMMA. Dengan mengasingkan pengendali koma daripada senarai argumen, anda boleh menghantar ungkapan kompleks kepada makro FOO asal:
#define COMMA , FOO(std::map<int COMMA int>, map_var);
Sintaks yang diperluas ini turut memudahkan rentetan hujah makro, membolehkan kod yang lebih dinamik dan bermaklumat:
#include <cstdio> #include <map> #include <typeinfo> #define STRV(...) #__VA_ARGS__ #define COMMA , #define FOO(type, bar) bar(STRV(type) \ " has typeid name \"%s\"", typeid(type).name()) int main() { FOO(std::map<int COMMA int>, std::printf); }
Pendekatan dipertingkat ini mencetak perkara berikut output:
std::map<int , int> has typeid name "St3mapIiiSt4lessIiESaISt4pairIKiiEEE"
Dengan memperkenalkan makro COMMA tersuai, ekspresif dan fleksibiliti makro dipertingkatkan dengan ketara, membolehkan pengendalian jenis data yang lebih kompleks dan rentetan hujah makro.
Atas ialah kandungan terperinci Bagaimanakah Koma dalam Makro C/C Dapat Meningkatkan Fleksibiliti Makro dan Pengendalian Hujah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!