文章目录
前言
本文记录的是在调试当中,需要用到宏定义
一、宏定义的一些“暗语”
__TIME__ :时间
__LINE__ :行号
__FILE__ :当前文件
\ :换行
## :将多个变量串联成一个
二、代码
代码如下(示例):
#include <stdio.h>
//#define __DEBUG
#ifdef __DEBUG
#define EPRINTF(func, fmt, args...) \
printf("%s [%d @ %s]: func" fmt, __TIME__, __LINE__, __FILE__, ##args);
#else
#define EPRINTF(fmt, args...) \
printf("%s [%d @ %s]: " fmt "\n", __TIME__, __LINE__, __FILE__, ##args);
#endif
#define DEBUG_PRINT printf("File %s line %d :"\
"x=%d,y=%d,z=%d",\
__FILE__,__LINE__,x,y,z)
int test(int m) {
return m = 1;
}
int main(int argc, char const *argv[])
{
printf("%s__%s__%d__%s\n", __FILE__, __FUNCTION__, __LINE__, __TIME__);
int x= 1, y =2, z = 3;
DEBUG_PRINT;
printf("\n");
printf("------------------------------------------\n");
EPRINTF("-->%s: %d\n", "hello", 2345);
printf("------------------------------------------\n");
return 0;
}
结果如图所示:
总结
捣鼓了一晚上,感觉宏定义的内容实在太多,而且带参数的宏定义理解起来挺吃力,需要多实践。虽然网上有很多文章介绍宏定义,但是如果不动手操练,就真的只停留在简单的宏定义替换。。。