va_arg

来自cppreference.com
< cpp‎ | utility‎ | variadic
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
 
在标头 <cstdarg> 定义
T va_arg( std::va_list ap, T );

va_arg 宏展开成对应来自 std::va_list ap 的下个参数的 T 类型表达式。

在调用 va_arg 前, ap 必须为到 va_startva_copy 的调用所初始化,中间不能夹带 va_end 的调用。 va_arg 宏的每次调用都修改 ap ,令它指向下个可变参数。

ap 中的下个参数类型(提升后)与 T 不兼容,则行为未定义,除非:

  • 一个类型是有符号整数类型,而另一类型是无符号整数类型,且值能用两个类型表示;或
  • 一个类型是指向 void 的指针,而另一类型是指向字符类型( charsigned charunsigned char )的指针。

若在 ap 中无更多参数时调用 va_arg ,则行为未定义。

参数

ap - std::va_list 类型的实例
T - ap 中下个参数的类型

展开值

ap 中的下个可变参数

示例

#include <iostream>
#include <cstdarg>
#include <cmath>
 
double stddev(int count, ...) 
{
    double sum = 0;
    double sum_sq = 0;
    std::va_list args;
    va_start(args, count);
    for (int i = 0; i < count; ++i) {
        double num = va_arg(args, double);
        sum += num;
        sum_sq += num*num;
    }
    va_end(args);
    return std::sqrt(sum_sq/count - (sum/count)*(sum/count));
}
 
int main() 
{
    std::cout << stddev(4, 25.0, 27.3, 26.9, 25.7) << '\n';
}

输出:

0.920258

参阅

启用对可变函数实参的访问
(宏函数)
(C++11)
制造可变函数实参的副本
(宏函数)
结束对可变函数实参的遍历
(宏函数)