Debug小技巧

​ 平时我们写程序需要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

转载请注明出处!!!

如果有写的不对或者不全面的地方 可通过主页的联系方式进行指正,谢谢