我正在尝试使用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
答案 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;
}