您的位置:首页 > 其它

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

2016-09-17 22:46 232 查看
/*
* 打印调试信息
*/
#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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: