将宏参数转换为字符串常量并考虑逗号

Convert a macro argument into a string constant and take into account commas

假设我有一个像这样的 C 宏定义产品版本:

#define FOO_VERSION 1,0,0,1

我想在 运行 时间打印它:

#define STRING_VALUE(x) #x

int main()
{
    std::cout << STRING_VALUE(FOO_VERSION) << std::endl;
}

这将输出一个字符串 "FOO_VERSION",而不是“1,0,0,1”。宏观 参数 'FOO_VERSION' 未被替换。所以我再试一次 这个:

#define STRING_VALUE(x) STRING_VALUE__(x)
#define STRING_VALUE__(x) #x

int main()
{
    std::cout << STRING_VALUE(FOO_VERSION) << std::endl;
}

在 Visual C++ 2013 中有效。

这是一个跨平台的应用程序,虽然只有五个 代码行。当我使用 clang 编译代码时,编译- 出现时间错误:“提供给类似函数的参数太多 宏调用”。我想原因是在中定义的逗号 'FOO_VERSION'。所以第三个版本:

#define STRING_VALUE(x) STRING_VALUE__(x)
#define STRING_VALUE__(a, b, c, d) #a "," #b "," #c "," #d

int main()
{
    std::cout << STRING_VALUE(FOO_VERSION) << std::endl;
}

此代码在 clang 中有效,但 Visual C++ 会输出警告: "not enough actual parameters for macro 'STRING_VALUE__'" 在 编译时,当然 运行-time 输出不正确。

我的问题:是否定义了这种预处理器行为?我可不可以有一个 STRING_VALUE 宏的通用版本 ?

您可以将参数视为单个可变参数宏:

#define FOO_VERSION 1,0,0,1

#define STRING_VALUE(...) STRING_VALUE__(__VA_ARGS__)
#define STRING_VALUE__(...) #__VA_ARGS__

这似乎适用于 gcc 和 Visual C++。