宏定义实现调试信息的打印控制

/*
 * 打印调试信息
 */
#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

你可能感兴趣的:(c/c++)