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

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

原文地址:https://www.cnblogs.com/huiz/p/9610674.html