平时我们写程序需要Debug的时候,在自己觉得会出错的地方加上printf输出相关信息用于测试。当printf的行过多的时候,如果我们忘记了删除,会导致多余的输出。
这时候,一个非常好用的Debug技巧分享给大家
#include <stdio.h>
#ifdef DEBUG //若有宏定义DEBUG
#define DBG(...) printf(__VA_ARGS__) //则将DBG()替换为printf(),其中__VA_ARGS__代表可变参
#else
#define DBG(...) //否则将DBG()替换为空
#endif
int main () {
DBG("hello, %s!\n", "zcy");
DBG("hello, %d\n", 2019);
DBG("hello, ACM!\n");
return 0;
}
如果我们g++编译的时候 -D DEBUG,就会输出DBG()的相关内容,如果直接g++编译,测试用的DBG不会输出。这样就非常方便的进行DEBUG啦
以下是运行效果图:
当然啦,宏定义的方式不唯一,比如这样定义也可以:
#ifdef DEBUG
#define DBG(a,b...) printf(a, ##b)
#else
#define DBG(a,b...)
#endif
如果有写的不对或者不全面的地方 可通过主页的联系方式进行指正,谢谢