C препроцессор, Stringify результат макроса - PullRequest
41 голосов
/ 06 августа 2010

Я хочу упорядочить результат расширения макроса.

Я пытался со следующим:

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

И TESTE расширяется до: "TEST", в то время какЯ пытаюсь получить это самое лучшее.Я знаю, что это правильное поведение препроцессора, но может ли кто-нибудь помочь мне найти другой?

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

Ответы [ 2 ]

74 голосов
/ 06 августа 2010

Как это:

#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);
}

Причина в том, что когда аргументы макроса подставляются в тело макроса, они раскрываются , если только не появляется с операторами препроцессора # или ## в этом макросе. Таким образом, str (со значением TEST в вашем коде) не раскрывается в QUOTE, но расширяется в EXPAND_AND_QUOTE.

15 голосов
/ 11 мая 2011

Чтобы уточнить немного, по сути, препроцессор был создан для выполнения еще одной "стадии". т.е.:

1-й случай:

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

2-й случай:

->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
...