C++的__VA_ARGS__、__FILE__、__FUNCTION__、__LINE__、__DATE__、__TIME__宏

时间:2021-04-11 17:04:07

        今天在以前的项目中看到几个从来没有见过的符号,分别是:__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上验证通过!