繁体   English   中英

将可变长度参数列表传递给另一个 function

[英]Passing variable length argument list to another function

我做了一个单独的 function display() 来显示数字,并想将初始化的参数指针发送到这个 function。我没有得到预期的结果。 这里出了什么问题? 我正在使用 gcc 版本 10.1.0 (GCC)

/* Expected OUTPUT */
99 + 68 -> Total = 167
11 + 79 + 32-> Total = 122
23 + 34 + 45 + 56 + 78 -> Total = 236 

/* Getting OUTPUT */
99 + 68 -> Total = 224
11 + 79 + 32 -> Total = 1410200528
23 + 34 + 45 + 56 + 78 -> Total = -1056735662


我的代码是:

/* Program in which the variable length list is passed to another function */
#include<stdio.h>
#include<stdarg.h>

int sum(int, ...);
void display(int,va_list);

int main(void)
{
    printf("\b\b-> Total = %d\n",sum(2,99,68));
    printf("\b\b-> Total = %d\n",sum(3,11,79,32));
    printf("\b\b-> Total = %d\n",sum(5,23,34,45,56,78));

    return 0;
}

int sum(int num, ...)
{
    int i;
    va_list ap;
    int arg,total = 0;
    va_start(ap,num);
    display(num,ap);

    for(i=0; i<num; i++)
    {
        arg=va_arg(ap,int);
        total+=arg;
    }

    va_end(ap);
    return total;
}

void display(int num,va_list ap)
{
    int i,argument;
    for(i=0; i<num; i++)
    {
        argument=va_arg(ap,int);
        printf("%d + ",argument);
    }
}

该规则从C11 7.16p3 开始是严格的:

object ap [类型为va_list ] 可以作为参数传递给另一个 function; 如果 function 调用带有参数 ap 的 va_arg 宏,则调用 function 中 ap 的值是不确定的,应在进一步引用 ap 之前传递给va_end

代码:

display(num,ap);
va_arg(ap, ...);

无效 - 一旦您将va_list传递给另一个 function,您只能调用va_end 您可以指向va_list

{
    ...
    display(num, &ap);
    va_arg(ap, int); // ok
    va_end(ap);
}
void display(int num, va_list *ap) {
    va_arg(*ap, int); // ok
}

但是您正在迭代va_list两次- 一次在 display 中,一次在sum中。 va_list记得它是 position,因此要迭代列表两次,您必须从一开始就初始化两个va_list 在你的情况下最简单的是初始化va_list两次。 所以你可以这样做:

int sum(int num, ...) {
    va_list ap;
    va_start(ap, num);
    display(num, ap);
    va_end(ap);

    int total = 0;
    va_start(ap, num);
    for (int i = 0; i < num; i++) {
        int arg = va_arg(ap, int);
        total += arg;
    }
    va_end(ap);

    return total;
}

void display(int num, va_list ap)
{
    for(int i = 0; i < num; i++)
    {
        int argument = va_arg(ap,int);
        printf("%d + ",argument);
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM