7

可能重复:
如何制作可变参数宏(可变数量的参数)

我想在基本 C 中有一个日志宏,它接受类似于printf并记录它们的参数。但是,我希望它的记录方式(日志级别、文件 vsstderr等)在编译时设置,而不是运行时设置;如果我将参数设置为忽略低级日志记录,则该方法什么都不做,并希望在代码之外进行优化。

到目前为止,我有一个宏,它是根据编译时定义的参数定义的。如果定义了参数,则记录转到我的日志方法(记录到文件),否则转到stderr. 但是,我只能将一个字符串传递给这个宏。log 方法能够接受不定数量的参数并使用printf语法工作。我想知道是否有办法设置我的宏,以便它将无限数量的参数传递给日志文件?

而且由于我怀疑答案是我做不到,还有另一种方法可以在基本 C 中实现我想要的(我不能使用 C++ 或 boost)。

4

4 回答 4

7

C99 有可以接受可变数量参数的宏。它们被称为可变参数宏

http://gcc.gnu.org/onlinedocs/cpp/Variadic-Macros.html

例子:

#define eprintf(...) fprintf (stderr, __VA_ARGS__)
#define dfprintf(stream, ...) fprintf(stream, "DEBUG: " __VA_ARGS__)
于 2012-06-11T19:44:37.617 回答
2

是的你可以。C99开箱即用地支持这一点。

语法如下:

#define debug(format, ...) fprintf (stderr, format, ## __VA_ARGS__)

于 2012-06-11T19:44:50.843 回答
0

请参阅 comp.lang.c 常见问题解答中的 Q10.26:如何编写带有可变数量参数的宏,或使用预处理器“关闭”具有可变数量参数的函数调用?

于 2012-06-11T19:45:45.843 回答
0

您可以使用省略号来定义带有可变数量参数的宏:

#define debug(format, ...) fprintf (stderr, format, __VA_ARGS__)

http://docs.redhat.com/docs/en-US/Red_Hat_Enterprise_Linux/4/html/Using_the_GNU_Compiler_Collection/variadic-macros.html

于 2012-06-11T19:48:56.853 回答