今天在以前的项目中看到几个从来没有见过的符号,分别是:__VA_ARGS__、__FILE__、__FUNCTION__、__LINE__,后来查询了下,原来是C++的宏,工作一年了,竟然连C++自带的几个宏定义都不认识,惭愧啊!
废话不多说了,现在来逐一介绍下这几个宏定义和用法。
__VA_ARGS__:可变参数的宏,这个可变参数的宏是新的C99规范中新增的;
__FILE__:返回当前代码文件所在的完整路径和文件名,这是一个绝对路径;
__FUNCTION__:返回当前代码所在函数名称;
__LINE__:返回当前代码所在行号(即在当前文件的多少行);
__DATE__:返回当前的日期;
__TIME__:返回当前的时间。
说下他们简单的应用,我自己写了一个很简单的demo,如下所示:
#include <iostream>
using namespace std;
#define LOG(...) {\
fprintf(stderr, "file location%s\nfunction name:%s\nline:%d\n", __FILE__, __FUNCTION__, __LINE__);\
fprintf(stderr, "date:%s\ntime:%s\n",__DATE__, __TIME__);\
fprintf(stderr, __VA_ARGS__);\
fprintf(stderr, "\n");\
}
int main(int argc, char** argv)
{
int x = 1024;
LOG("x = %d, %s, %s", x, "hello world", "you are the best");
return 0;
}
以上代码在VS2008上验证通过!