Namespaces
Variants

va_arg

From cppreference.net
Utilities library
Definiert in Header <cstdarg>
T va_arg ( std :: va_list ap, T ) ;

Das va_arg Makro expandiert zu einem Ausdruck vom Typ T , der dem nächsten Parameter aus der va_list ap entspricht.

Vor dem Aufruf von va_arg muss ap durch einen Aufruf von entweder va_start oder va_copy initialisiert werden, ohne dass zwischenzeitlich va_end aufgerufen wurde. Jeder Aufruf des va_arg -Makros modifiziert ap , um auf das nächste variable Argument zu zeigen.

Wenn der Typ des nächsten Arguments in ap (nach Durchführung von Promotions) nicht kompatibel mit T ist, ist das Verhalten undefiniert, es sei denn:

  • ein Typ ist ein vorzeichenbehafteter Ganzzahltyp, der andere Typ ist der entsprechende vorzeichenlose Ganzzahltyp, und der Wert ist in beiden Typen darstellbar; oder
  • ein Typ ist ein Zeiger auf void und der andere ist ein Zeiger auf einen Zeichentyp ( char , signed char , oder unsigned char ).

Wenn va_arg aufgerufen wird, wenn keine weiteren Argumente in ap vorhanden sind, ist das Verhalten undefiniert.

Inhaltsverzeichnis

Parameter

ap - eine Instanz des va_list -Typs
T - der Typ des nächsten Parameters in ap

Erweiterter Wert

Der nächste Variablenparameter in ap .

Beispiel

#include <cstdarg>
#include <cstdio>
#include <iostream>
void print_variance(std::size_t count, const char* fmt, ...)
{
    double sum = 0;
    double sum_sq = 0;
    std::va_list args;
    va_start(args, fmt);
    for (std::size_t i = count; i--;)
    {
        double num = va_arg(args, double);
        sum += num;
        sum_sq += num*num;
    }
    va_end(args);
    std::printf(fmt, sum_sq / count - (sum / count) * (sum / count));
}
void nano_printf(const char* fmt, ...)
{
    std::va_list args;
    va_start(args, fmt);
    for (const char* p = fmt; *p != '\0'; ++p)
    {
        switch (*p)
        {
        case '%':
            switch (*++p) // Format-Symbol lesen
            {
                case 'i':
                    std::cout << va_arg(args, int);
                    continue;
                case 'f':
                    std::cout << va_arg(args, double);
                    continue;
                case 's':
                    std::cout << va_arg(args, const char*);
                    continue;
                case 'c':
                    std::cout << static_cast<char>(va_arg(args, int));
                    continue;
                case '%':
                    std::cout << '%';
                    continue;
                /* ...weitere Fälle... */
            }
            break; // Formatfehler...
        case '\n':
            std::cout << '\n';
            continue;
        case '\t':
            std::cout << '\t';
            continue;
        /* ...weitere Fälle... */
        }
        std::cout << *p;
    }
    va_end(args);
}
int main()
{
    print_variance(4, "%f\n", 25.0, 27.3, 26.9, 25.7);
    nano_printf("Args: %i%% %c%f %s\n", 42, '#', 3.14, "C++");
}

Ausgabe:

0.846875
Args: 42% #3.14 C++

Siehe auch

ermöglicht den Zugriff auf variadische Funktionsargumente
(Funktionsmakro)
(C++11)
erstellt eine Kopie der variadischen Funktionsargumente
(Funktionsmakro)
beendet die Verarbeitung der variadischen Funktionsargumente
(Funktionsmakro)
C-Dokumentation für va_arg