通过void **将参数传递给函数

时间:2017-07-04 19:12:59

标签: c c89

我正在尝试使用void *通过函数传递参数来提供任何类型的参数。但由于某些原因我不明白,在函数内部无法读取数据。

这是公司职能的再现行为。 Live on Coliru

#include <stdio.h>

typedef struct
{
    double d1, d2;
} S;

double doStuff(void ** args)
{
    double * a = (double*)args;

    printf("a[0] = %lf\n", a[0]);
    printf("a[1] = %lf\n", a[1]);

    double r = a[0] + a[1];
    return r;
}

int main(void) {

    S s;
    s.d1 = 10.0;
    s.d2 = 10.0;

    S* ptr = &s;

    void* args[2];
    args[0] = &ptr->d1;
    args[1] = &ptr->d2;

    double d = doStuff(args);

    printf("d = %lf\n", d);

    return 0;
}

它的输出

a[0] = 0.000000
a[1] = 0.000000
d = 0.000000

1 个答案:

答案 0 :(得分:1)

您应该将代码更改为:

double doStuff(void ** args)
{
    double ** a = (double**)args;

    printf("a[0] = %lf\n", *a[0]);
    printf("a[1] = %lf\n", *a[1]);

    double r = *a[0] + *a[1];
    return r;
}

修改

OP要求更改main而不是doStuff(他/她不拥有)。

现在,正如@Eugene Sh所指出的那样,函数doStuff被削弱了,因为它要求一个双指针参数,但是用作指针加倍。

main中的更改只是传递一个指向double的指针,但只是为了让编译器满意而转换为void**

int main(void) {

    S s;
    s.d1 = 10.0;
    s.d2 = 10.0;

    S* ptr = &s;

    double args[2];     // our pointer to double
    args[0] = ptr->d1;
    args[1] = ptr->d2;

    double d = doStuff((void**)args); // cast to void**

    printf("d = %lf\n", d);

    return 0;
}