在 VC 2015 上使用带有字符串的宏失败

为什么编译失败?

char programDate[] = "("__DATE__")";

但这编译得很好(见空间):

But this compiles fine (see space):

char programDate[] = "(" __DATE__")";

我知道 VC2015 现在支持文字运算符.但这不应该在编译阶段吗?__DATE__ 应该已经被预处理器处理了.这是怎么回事?

I do know VC2015 now supports literal-operators. But shouldn't that be in compilation phase? __DATE__ should have been processed by the pre-processor. What is going on here?

我想到了一些 Unicode/非 Unicode 构建的混合匹配问题 - 但它没有帮助.这不仅是预定义宏的问题,还有用户定义的问题:

I thought of some mix-match issue with Unicode/non-Unicode build - but it doesn't help. It's not just issue with pre-defined macros, but with user defined also:

#define MACRO "abc"
char data[] = "("MACRO")";

Error C3688 invalid literal suffix '__DATE__'; literal operator or literal operator template 'operator ""__DATE__' not found

推荐答案

从 C++11 开始,用户定义的文字就存在并且是预处理的一部分.语法是:

Since C++11, user-defined literals exist and are part of preprocessing. The grammar is:

preprocessing-token:
    user-defined-string-literal
    // other stuff...

user-defined-string-literal:
    string_literal ud-suffix

ud-suffix:
    identifier

所以 "("__DATE__ 匹配 preprocessing-token,但 "(" __DATE__ 不匹配 (那是两个单独的预处理标记).

So "("__DATE__ matches preprocessing-token, but "(" __DATE__ doesn't (that is two separate preprocessing tokens).

宏替换发生在标记化之后.由于您的第一个示例中没有标记 __DATE__,因此没有替换.

Macro replacement happens after tokenization. Since there is no token __DATE__ in your first example, there is no replacement.

相关文章