49

我想对宏扩展的结果进行字符串化。

我尝试过以下方法:

#define QUOTE(str) #str
#define TEST thisisatest
#define TESTE QUOTE(TEST)

并且 TESTE 扩展为:“TEST”,而我正在尝试获得“thisisatest”。我知道这是预处理器的正确行为,但任何人都可以帮助我实现另一种方法吗?

Using TESTE #TEST is not valid
Using TESTE QUOTE(thisisatest) is not what I'm trying to do
4

2 回答 2

79

像这样:

#include <stdio.h>

#define QUOTE(str) #str
#define EXPAND_AND_QUOTE(str) QUOTE(str)
#define TEST thisisatest
#define TESTE EXPAND_AND_QUOTE(TEST)

int main() {
    printf(TESTE);
}

原因是当宏参数被替换到宏主体中时,它们会被扩展,除非它们与该宏中的 # 或 ## 预处理器运算符一起出现。因此,strTEST在您的代码中具有值)没有在 中扩展QUOTE,而是在EXPAND_AND_QUOTE.

于 2010-08-05T21:37:42.777 回答
16

为了更清楚一点,基本上预处理器是用来执行另一个“阶段”的。IE :

第一种情况:

->TESTE
->QUOTE(TEST) # preprocessor encounters QUOTE 
 # first so it expands it *without expanding its argument* 
 # as the '#' symbol is used
->TEST

第二种情况:

->TESTE
->EXPAND_AND_QUOTE(TEST)
->QUOTE(thisisatest) 
  # after expanding EXPAND_AND_QUOTE
  # in the previous line
  # the preprocessor checked for more macros
  # to expand, it found TEST and expanded it
  # to 'thisisatest'
->thisisatest
于 2011-05-11T14:18:43.817 回答