如果附加参数的数量未知,我如何遍历va_list?
#include <stdio.h>
#include <stdarg.h>
int add(int x, int y, ...) {
va_list intargs;
int temp = 0;
va_start(intargs, y);
int i;
for (i = 0; i < 3; i++) { /* How can I loop through any number of args? */
temp += va_arg(intargs, int);
}
va_end(intargs);
return temp + x + y;
}
int main() {
printf("The total is %d.\n", add(1, 2, 3, 4, 5));
return 0;
}
答案 0 :(得分:17)
在使用可变长度参数列表时,必须以某种方式指示参数的数量(如果您正在编写可移植代码)。您现在可能正在考虑“但是printf并不要求您指出一些参数!”
是的,但是可以通过首先解析%格式说明符的格式字符串来推断出数字。
答案 1 :(得分:15)
使用sentinel值作为终结符,例如NULL
或-1
答案 2 :(得分:2)
您可能希望执行诸如将参数数量作为第一个参数传递的内容。
E.g。看这里: http://www.cplusplus.com/reference/clibrary/cstdarg/va_start/
此处有更多讨论:http://www.learncpp.com/cpp-tutorial/714-ellipses-and-why-to-avoid-them/
变量参数可能是危险的,所以如果可能的话我会尽量避免它们。传递包含大小和指向元素数组的指针的“向量”类型会更安全。
答案 3 :(得分:1)
上面的两个答案建议添加第一个参数来指示参数数量未达到要求:参数数量未知。
最后使用哨兵值(或一系列哨兵值)是解决问题的唯一方法。
答案 4 :(得分:0)
您可以使用第一个参数来表示元素数量,然后可以将任意数量的元素传递给函数。
这是一个典型的通话:
int i = add(5, 20, 30, 40, 50, 60);
要累加5个数字,因此第一个参数是 5 。然后剩下的就是五个要累加的数字。
该函数将是:
int add(int argc, ...)
{
int result = 0;
va_list ptr;
va_start(ptr, argc);
for (int i = 0; i < argc; i++)
{
result += va_arg(ptr, int);
}
return result;
}
参考: