Jak używać argumentu Macro jako literału ciągu?

91

Próbuję dowiedzieć się, jak napisać makro, które przekaże zarówno ciąg znaków reprezentacji nazwy zmiennej, jak i samą zmienną do funkcji.

Na przykład biorąc pod uwagę następującą funkcję.

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

Chciałbym napisać makro, więc mogę to zrobić:

int my_val = 5;
CALL_DO_SOMETHING(my_val);

Który wydrukowałby: my_val: 5

Próbowałem wykonać następujące czynności:

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

Jednak, jak można się domyślić, wartość WARIANCJA wewnątrz cudzysłowów nie jest zastępowana, ale jest przekazywana jako literał ciągu „ZMIENNA”. Chciałbym więc wiedzieć, czy istnieje sposób na przekształcenie argumentu makra w sam literał ciągu.

Ian
źródło
Jak próbujesz to wykorzystać?
chris

Odpowiedzi:

145

Użyj #operatora preprocesora :

#define CALL_DO_SOMETHING(VAR) do_something(#VAR, VAR);
Morwenn
źródło
28

Chcesz użyć operatora naciągania:

#define STRING(s) #s

int main()
{
    const char * cstr = STRING(abc); //cstr == "abc"
}
chris
źródło
9

Być może wypróbujesz to rozwiązanie:

#define QUANTIDISCHI 6
#define QUDI(x) #x
#define QUdi(x) QUDI(x)
. . . 
. . .
unsigned char TheNumber[] = "QUANTIDISCHI = " QUdi(QUANTIDISCHI) "\n";
Zili
źródło
Jak to odpowiada na pytanie lub jak jest pomocne?
jirigracik
1
@jirigracik - Pozwala również uzyskać prezentację ciągów rozwijania makr, w przeciwieństwie do innych odpowiedzi
grepcake
3
Myślę, że warto byłoby wyjaśnić, dlaczego samo posiadanie QUDI(x)nie wystarczy.
LRDPRDX
8
#define NAME(x) printf("Hello " #x);
main(){
    NAME(Ian)
}
//will print: Hello Ian
Mikele Shtembari
źródło
Nie jestem do końca pewien, ale wygląda na to, że "Hello" #x"(i #x "Hello") powoduje sklejanie sznurka bez spacji, co jest pożądane w niektórych przypadkach, więc jest to dość dobra odpowiedź.
Smar
1
@Smar Upewnij się, że wstawiłeś spację po stałym ciągu Hello: "Hello " #x
jack
OK, tak myślałem, powinieneś to również zmienić w swojej odpowiedzi, ponieważ jest to cenna informacja :)
Smar