我正在使用这个简单的宏来记录我的程序的事件:
#define _ERROR(format, args...) \
{ \
time_t t = time(0);\
struct tm * now = localtime( & t );\
fprintf(stderr, "[ERROR %d-%d-%d %d:%d:%d]: ",now->tm_year + 1900,\
now->tm_mon + 1, now->tm_mday,\
now->tm_hour, now->tm_min, now->tm_sec); \
fprintf(stderr, format , ## args);\
printf("\n");\
fflush(stderr);\
}
它使用 GCC 和 MinGW 在 Linux 和 Windows 上愉快地编译。虽然 MSVC 11 无法编译。
注意:我在理解这一点和之前的 SO 问题的答案时遇到了困难。我想我遗漏了一些关于宏和/或可变参数计数的东西。所以:
- 是什么
__VA_ARGS__
?我必须使用它吗? - 我是否必须仅将它用于 MSVC 可编译代码?
__VA_ARGS__
由于缺乏这些人员,上面的代码是错误的/非标准的/不优雅的吗?