怎樣寫引數個數可變的巨集?
一種流行的技巧是用乙個單獨的用括弧括起來的的「引數」 定義和呼叫巨集, 引數在巨集擴充套件的時候成為類似printf() 那樣的函式的整個引數列表。
#define debug(args) (printf("debug: "), printf args)
if(n != 0) debug(("n is %d\n", n));
明顯的缺陷是呼叫者必須記住使用一對額外的括弧。
gcc 有乙個擴充套件可以讓函式式的巨集接受可變個數的引數。但這不是標準。另一種可能的解決方案是根據引數個數使用多個巨集(debug1, debug2, 等等), 或者用逗號玩個這樣的花招:
#define debug(args) (printf("debug: "), printf(args))
#define _ ,
debug("i = %d" _ i);
c99 引入了對引數個數可變的函式式巨集的正式支援。在巨集「原型」 的末尾加上符號. . . (就像在引數可變的函式定義中), 巨集定義中的偽巨集 va args 就會在呼叫是替換成可變引數。
最後, 你總是可以使用真實的函式, 接受明確定義的可變引數。如果你需要替換巨集, 使用乙個函式和乙個非函式式巨集, 如#define printfmyprintf。
怎樣寫引數個數可變的巨集
if ifdef if defined 在 gnu c 中,巨集可以接受可變數目的引數,就象函式一樣,例如 define pr debug fmt,arg.printk kern debug fmt,arg 用可變引數巨集 variadic macros 傳遞可變參數列 你可能很熟悉在函式中使用可變...
怎樣寫引數個數可變的巨集
用可變引數巨集 variadic macros 傳遞可變參數列 你可能很熟悉在函式中使用可變參數列,如 void printf const char format,直到最近,可變參數列還是只能應用在真正的函式中,不能使用在巨集中。c99編譯器標準終於改變了這種局面,它允許你可以定義可變引數巨集 va...
怎樣寫引數個數可變的巨集
if ifdef if defined 在 gnu c 中,巨集可以接受可變數目的引數,就象函式一樣,例如 define pr debug fmt,arg.printk kern debug fmt,arg 用可變引數巨集 variadic macros 傳遞可變參數列 你可能很熟悉在函式中使用可變...