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\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上验证通过!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值