我见过一个函数,其原型是:
int myfunc(void** ppt)
Run Code Online (Sandbox Code Playgroud)
该函数在C文件中作为a = myfunc(mystruct**var1)调用;
其中mystruct是我们拥有的结构之一的typedef.
这在MSVC6.0中没有任何编译错误,但是当我用其他一些C编译器编译它时,它会在调用此函数的地方出错,并显示错误消息:
类型mystruct**的参数与void**类型的参数不兼容
myfunc()的参数保持为void**,因为它似乎是一个通用的malloc类函数,可以使用各种结构变量类型进行内存分配
mystruct**,但它没有工作]-广告
Geo*_*don 22
该comp.lang.c常见问题解决了这个问题详细问题4.9.简而言之,他们说用一个指向指针的任意指针并不是严格可移植的void **; 他们接着解释说"这样的代码可能有用,有时也会被推荐,但它依赖于具有相同内部表示的所有指针类型(这是常见的,但不是通用的)." 他们继续解释说" void **你玩的任何价值必须是void *某个地方的实际值的地址; (void **)&dp虽然他们可能会关闭编译器,但它们是不可移植的(并且可能甚至不能做你想做的事情)."
因此,您可以使用以下代码安全/可移植地实现所需的行为:
some_type *var1 = foo();
void *tmp_void_ptr = (void *)var1;
myfunc(&tmp_void_ptr);
Run Code Online (Sandbox Code Playgroud)
void** 是有效的,但是,根据您的错误消息,您可能必须显式转换参数,如下所示:
mystruct **var1;
x = myfunc ((void**) var1);
Run Code Online (Sandbox Code Playgroud)
那是因为myfunc函数期望void**类型.虽然void*可以隐式地转换为任何其他指针,但对于双指针则不然 - 您需要显式地转换它.