Como usar o argumento Macro como literal de string?

92

Estou tentando descobrir como escrever uma macro que passará uma representação literal de string de um nome de variável junto com a própria variável em uma função.

Por exemplo, dada a seguinte função.

void do_something(string name, int val)
{
   cout << name << ": " << val << endl;
}

Eu gostaria de escrever uma macro para fazer isso:

int my_val = 5;
CALL_DO_SOMETHING(my_val);

Que imprimiria: my_val: 5

Tentei fazer o seguinte:

#define CALL_DO_SOMETHING(VAR) do_something("VAR", VAR);

No entanto, como você pode imaginar, o VAR dentro das aspas não é substituído, mas apenas passado como a string literal "VAR". Portanto, gostaria de saber se existe uma maneira de transformar o argumento da macro em uma string literal.

Ian
fonte
Como você está tentando usar isso?
Chris

Respostas:

149

Use o #operador de pré-processador :

#define CALL_DO_SOMETHING(VAR) do_something(#VAR, VAR);
Morwenn
fonte
31

Você deseja usar o operador de stringizing:

#define STRING(s) #s

int main()
{
    const char * cstr = STRING(abc); //cstr == "abc"
}
Chris
fonte
11

Talvez você tente esta solução:

#define QUANTIDISCHI 6
#define QUDI(x) #x
#define QUdi(x) QUDI(x)
. . . 
. . .
unsigned char TheNumber[] = "QUANTIDISCHI = " QUdi(QUANTIDISCHI) "\n";
Zili
fonte
Como isso responde à pergunta ou como é útil?
jirigracik,
2
@jirigracik - Também permite obter a apresentação da string de expansão macro, ao contrário de outras respostas
grepcake
4
Acho que seria útil explicar por que simplesmente QUDI(x)não basta.
LRDPRDX
Isso é exatamente o que eu estava procurando. A explicação de por que funciona seria útil, mas resolveu meu problema (o que as outras respostas não resolveram).
GMc
8
#define NAME(x) printf("Hello " #x);
main(){
    NAME(Ian)
}
//will print: Hello Ian
Mikele Shtembari
fonte
Não estou totalmente certo, mas parece que "Hello" #x"(e #x "Hello") faz com que a string seja colada sem espaço, o que é o desejado em alguns casos, então esta é uma resposta bastante boa.
Smar
1
@Smar Certifique-se de colocar um espaço após a string constante Hello: "Hello " #x
jack
Ok, pensei que sim, você deve editar isso em sua resposta também, pois é uma informação valiosa :)
Smar