va_arg
From cppreference.com
| ヘッダー <cstdarg> で定義 |
||
| T va_arg( std::va_list ap, T ); |
||
va_arg マクロは、va_list ap からの次のパラメータに対応する型 T の式に展開されます。
va_arg を呼び出す前に、ap は va_start または va_copy のいずれかの呼び出しによって初期化されている必要があり、その間に va_end の呼び出しがあってはなりません。va_arg マクロの各呼び出しは、ap を変更して次の可変引数を指すようにします。
ap 内の次の引数の型 (昇格後) が T と互換性がない場合、以下のいずれかの条件が満たされない限り、動作は未定義です。
- 一方の型が符号付き整数型で、もう一方の型が対応する符号なし整数型であり、その値が両方の型で表現可能である場合。または
- 一方の型が void へのポインタで、もう一方の型が文字型 (char, signed char, または unsigned char) へのポインタである場合。
ap に引数が残っていないときに va_arg が呼び出された場合、動作は未定義です。
目次 |
[編集] パラメータ
| ap | - | va_list 型のインスタンス |
| T | - | ap 内の次のパラメータの型 |
[編集] 展開された値
ap 内の次の可変パラメータ。
[編集] 例
このコードを実行
#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++"); }
出力
0.846875 Args: 42% #3.14 C++
[編集] 関連項目
| 可変長引数関数へのアクセスを有効にする (関数マクロ) | |
| (C++11) |
可変長引数のコピーを作成する (関数マクロ) |
| 可変長引数の走査を終了する (関数マクロ) | |
| C documentation の va_arg
| |