今天在以前的项目中看到几个从来没有见过的符号,分别是:__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
function name:%s
line:%d
", __FILE__, __FUNCTION__, __LINE__);
fprintf(stderr, "date:%s
time:%s
",__DATE__, __TIME__);
fprintf(stderr, __VA_ARGS__);
fprintf(stderr, "
");
}
int main(int argc, char** argv)
{
int x = 1024;
LOG("x = %d, %s, %s", x, "hello world", "you are the best");
return 0;
}
以上代码在VS2008上验证通过!