PRintf()和fprintf()這些輸出函數(shù)的參數(shù)是可變的,在調(diào)試程序時(shí),你可能希望定義自己的參數(shù)可變的輸出函數(shù),
那么可變參數(shù)宏會(huì)是一個(gè)選擇。
C99中規(guī)定宏可以像函數(shù)一樣帶有可變參數(shù),比如
#define LOG(format, ...) fprintf(stdout, format, __VA_ARGS__)
其中,...表示參數(shù)可變,__VA_ARGS__在預(yù)處理中為實(shí)際的參數(shù)集所替換
GCC中同時(shí)支持如下的形式
#define LOG(format, args...) fprintf(stdout, format, args)
其用法和上面的基本一致,只是參數(shù)符號(hào)有變化
有一點(diǎn)需要注意,上述的宏定義不能省略可變參數(shù),盡管你可以傳遞一個(gè)空參數(shù),這里有必要提到"##"連接符號(hào)的用法。
"##"的作用是對(duì)token進(jìn)行連接,在上例中,format、__VA_ARGS__、args即是token,
如果token為空,那么不進(jìn)行連接,所以允許省略可變參數(shù)(__VA_ARGS__和args),對(duì)上述變參宏做如下修改
#define LOG(format, ...) fprintf(stdout, format, ##__VA_ARGS__)
#define LOG(format, args...) fprintf(stdout, format, ##args)
上述的變參宏定義不僅能自定義輸出格式,而且配合#ifdef #else #endif在輸出管理上也很方便,
比如調(diào)試時(shí)輸出調(diào)試信息,正式發(fā)布時(shí)則不輸出,可以這樣
#ifdef DEBUG
#define LOG(format, ...) fprintf(stdout, ">> "format"/n", ##__VA_ARGS__)
#else
#define LOG(format, ...)
#endif
在調(diào)試環(huán)境下,LOG宏是一個(gè)變參輸出宏,以自定義的格式輸出;
在發(fā)布環(huán)境下,LOG宏是一個(gè)空宏,不做任何事情。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注