【问题标题】:Nested macro expansion嵌套宏扩展
【发布时间】:2015-07-24 12:10:52
【问题描述】:

我不确定这是否是正确使用的术语,但是我的问题是宏调用(“PLUGIN_NAME”)作为另一个宏调用(“IMPLEMENT_MODULE”)的参数,而后者又将其打印为字符串,将该参数打印为宏调用(“somePLUGIN_NAME”)而不是扩展结果(“someSomePluginName”)。

请注意,“IMPLEMENT_MODULE”是一个 API 调用,因此我无法更改它。

#define IMPLEMENT_MODULE(name) something##name

#define PLUGIN_NAME SomePluginName
#define _STR(s) #s
#define STR(s) _STR(s)
#define PLUGIN_NAME_STR STR(PLUGIN_NAME)

int main()
{
    string expected = "somethingSomePluginName";
    string actual = STR(IMPLEMENT_MODULE(PLUGIN_NAME));

    printf("expected: %s || actual: %s\n", expected.c_str(), actual.c_str());
    assert(expected == actual);
}

我把它放在这里: http://codepad.org/FRzChJtD

【问题讨论】:

    标签: c++ macros


    【解决方案1】:

    您需要另一个辅助宏在宏扩展后连接预处理器标记:

    #define IMPLEMENT_MODULE_2(A, B) A##B
    #define IMPLEMENT_MODULE(name) IMPLEMENT_MODULE_2(something, name)
    

    查看工作example here

    这个技术解释是,如果预处理器找到标记粘贴 (##) 或字符串化运算符 (#),宏扩展将不会发生

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-10-19
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-11-03
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多