Udostępnij za pośrednictwem


Makra Wariadyczne

Makra Wariadyczne są makrami przypominającymi funkcje, które zawierają zmienną liczbę argumentów.

Uwagi

Aby użyć makr wariadycznych, wielokropek może być określony jako końcowy argument formalny w definicji makra, a identyfikator __VA_ARGS__ zastępczy może być używany w definicji w celu wstawienia dodatkowych argumentów. __VA_ARGS__ jest zastępowany przez wszystkie argumenty pasujące do wielokropka, w tym przecinki między nimi.

Język C Standard określa, że co najmniej jeden argument musi zostać przekazany do wielokropka, aby upewnić się, że makro nie jest rozpoznawane jako wyrażenie z przecinkiem końcowym. Tradycyjna implementacja języka Microsoft C++ pomija końcowy przecinek, jeśli do wielokropka nie są przekazywane żadne argumenty. Po ustawieniu /Zc:preprocessor opcji kompilatora końcowy przecinek nie jest pomijany.

Przykład

// variadic_macros.cpp
#include <stdio.h>
#define EMPTY

#define CHECK1(x, ...) if (!(x)) { printf(__VA_ARGS__); }
#define CHECK2(x, ...) if ((x)) { printf(__VA_ARGS__); }
#define CHECK3(...) { printf(__VA_ARGS__); }
#define MACRO(s, ...) printf(s, __VA_ARGS__)

int main() {
    CHECK1(0, "here %s %s %s", "are", "some", "varargs1(1)\n");
    CHECK1(1, "here %s %s %s", "are", "some", "varargs1(2)\n");   // won't print

    CHECK2(0, "here %s %s %s", "are", "some", "varargs2(3)\n");   // won't print
    CHECK2(1, "here %s %s %s", "are", "some", "varargs2(4)\n");

    // always invokes printf in the macro
    CHECK3("here %s %s %s", "are", "some", "varargs3(5)\n");

    MACRO("hello, world\n");

    MACRO("error\n", EMPTY); // would cause error C2059, except VC++
                             // suppresses the trailing comma
}
here are some varargs1(1)
here are some varargs2(4)
here are some varargs3(5)
hello, world
error

Zobacz też

Makra (C/C++)