| Defined in header <stdarg.h> | ||
|---|---|---|
| void va_start( va_list ap, parmN ); | (until C23) | |
| void va_start( va_list ap, ... ); | (since C23) | 
The va_start macro enables access to the variable arguments following the named argument parmN(until C23).
va_start shall be invoked with an instance to a valid va_list object ap before any calls to va_arg.
| If  | (until C23) | 
| Only the first argument passed to  | (since C23) | 
| ap | - | an instance of the va_listtype | 
| parmN | - | the named parameter preceding the first variable parameter | 
(none)
#include <stdio.h>
#include <stdarg.h>
 
int add_nums_C99(int count, ...)
{
    int result = 0;
    va_list args;
    va_start(args, count); // count can be omitted since C23
 
    for (int i = 0; i < count; ++i) {
        result += va_arg(args, int);
    }
 
    va_end(args);
    return result;
}
 
#if __STDC_VERSION__ > 201710L
// Same as above, valid since C23
int add_nums_C23(...)
{
    int result = 0;
    va_list args;
    va_start(args);
 
    int count = va_arg(args, int);
    for (int i = 0; i < count; ++i) {
        result += va_arg(args, int);
    }
 
    va_end(args);
    return result;
}
#endif
 
int main(void)
{
    printf("%d\n", add_nums_C99(4, 25, 25, 50, 50));
#if __STDC_VERSION__ > 201710L
    printf("%d\n", add_nums_C23(4, 25, 25, 50, 50));
#endif
}Possible output:
150 150
| accesses the next variadic function argument (function macro) | |
| (C99) | makes a copy of the variadic function arguments (function macro) | 
| ends traversal of the variadic function arguments (function macro) | |
| holds the information needed by va_start, va_arg, va_end, and va_copy (typedef) | |
| C++ documentation for va_start | |
    © cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
    https://en.cppreference.com/w/c/variadic/va_start