3
gcc (GCC) 4.7.2
c89

是否可以对可变参数宏进行字符串化?

我有以下宏,我想从fmtand 参数输出结果字符串。

#define ERROR_MESSAGE(priority, fmt, ...)        \
    do {                                         \
        MODULE_LOG(priority, fmt, ##__VA_ARGS__);\
} while(0)

因此,我只想获取 the 的完整字符串,fmt然后##__VA_ARGS__我可以将其分配给 achar *以对其执行一些额外的操作。

4

1 回答 1

6

不。预处理发生在甚至编译代码之前。它存在于与执行程序完全不同的宇宙中。您可以做的一件事是只运行预处理步骤并检查输出(使用 gcc 开关-E打印预处理器输出)。

您最多可以做的是将其重定向到一个文件,然后在程序中读取该文件。


进一步考虑,让我从“不”退后,将其改为“也许”。看看我的另一个答案,它为可变参数宏实现了一个“foreach”宏。

因此,使用APPLYXn(并且,隐式地,PPNARG),您可以STR(x) #x像这样将宏应用于 args(nb 写成,APPLYXn最多可以处理 15 个参数):

#define X(x) #x
#define ERROR_MESSAGE(priority, fmt, ...)        \
    "do {MODULE_LOG(" X(priority) X(fmt) APPLYXn(__VA_ARGS__) ");} while(0)"

int main() {
    printf("%s\n", ERROR_MESSAGE(3, "%d", 5) );
    return 0;
}

gcc -E生产

# 1 "strvar.c"
# 1 "<built-in>"
# 1 "<command-line>"
# 1 "strvar.c"
# 71 "strvar.c"

int main() {
    printf("%s\n", "do {MODULE_LOG(" "3" "\"%d\"" "5" ");} while(0)" );
    return 0;
}

编译器会将所有这些字符串文字连接成一个字符串。

于 2013-04-26T05:38:14.787 回答