/*
* 打印调试信息
*/
#define DEBUG_SWITCH
#ifdef DEBUG_SWITCH
#define pr_debug(fmt,args...) printf(fmt, ##args)
#else
#define pr_debug(fmt,args...) /* do nothing */
#endif
/*
* 打印错误信息
* 自动打印发生错误时代码所在的位置
*/
#define ERR_DEBUG_SWITCH
#ifdef ERR_DEBUG_SWITCH
#define pr_err(fmt,args...) printf("File:<%s> Fun:[%s] Line:%d\n "fmt, __FILE__, __FUNCTION__, __LINE__, ##args)
#else
#define pr_err(fmt,args...) /* do nothing */
#endif
通过宏DEBUG_SWITCH、ERR_DEBUG_SWITCH的定义与否,来决定是否将信息打印出来。
在GNU C中,宏也可以接受可变数目的参数,例如:
#define pr_debug(fmt,args...) printf(fmt, ##args)
这里args 表示其余的参数可以是零个或多个,这些参数以及参数之间的逗号构成args 的值,在宏扩展时替换args