Namensräume
Varianten
Aktionen

va_arg

Von cppreference.com
< cpp‎ | utility‎ | variadic
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
Definiert im Header <cstdarg>
T va_arg( std::va_list ap, T );

Das Makro va_arg 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 worden sein, ohne dazwischenliegenden Aufruf von va_end. Jede Ausführung des Makros va_arg modifiziert ap so, dass es auf das nächste variable Argument zeigt.

Wenn der Typ des nächsten Arguments in ap (nach Promotionen) 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 Zeigertyp (char, signed char oder unsigned char).

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

Inhalt

[edit] Parameter

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

[edit] Erweiterter Wert

Der nächste variable Parameter in ap.

[edit] 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) // read format symbol
            {
                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;
                /* ...more cases... */
            }
            break; // format error...
        case '\n':
            std::cout << '\n';
            continue;
        case '\t':
            std::cout << '\t';
            continue;
        /* ...more cases... */
        }
        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++

[edit] Siehe auch

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