2

这是来自 OpenCL 教程。我有:

void* args[4] = {(void*)5, (void*)123, NULL, NULL}; 
cl_mem mem_list[2] = {mem_d1, mem_d2}; // mem_d1 and mem_d2 are cl_mem objects
void* args_mem_loc[2] = {&args[2], &args[3]};
status = clEnqueueNativeKernel(*queue, nativeKernel, args, 4, 2, mem_list, args_mem_loc, 0, NULL, NULL); // http://www.khronos.org/registry/cl/sdk/1.0/docs/man/xhtml/clEnqueueNativeKernel.html

我不断收到编译器错误(在status = clEnqueueNativeKernel(*queue ...它正在谈论的参数是args_mem_loc)的行上。

error C2664: 'clEnqueueNativeKernel' : cannot convert parameter 7 from 'void *[2]' to 'const void **'

args_mem_loc 是一个指向 void 指针数组的 void 指针,它使用的所有变量都是在堆栈上创建的(对吗?我很确定)。那么为什么编译器会认为它是 void* [2] 呢?

4

2 回答 2

3

这个:

void* args_mem_loc[2] = {&args[2], &args[3]};

隐式转换为:

void **

这不能隐式转换为:

const void **

因为您可以将 a 分配const void *给 avoid *并破坏 const 的正确性。

编译器说args_mem_loc是 avoid *[2]因为它就是这样。如果要传递可以隐式转换为 的数组const void **,请声明args_mem_locconst void *arg_mem_loc[2]= {...};

顺便说一句,该const void **函数的参数应该是const void * const *; 在这种情况下,隐式转换将起作用。这表明该函数不会修改args_mem_loc,因为通过该指针分配是非法的,因此允许隐式转换。

于 2013-08-21T18:21:28.447 回答
1

当您有一个指向数组的指针时,例如void* args_mem_loc[2]这意味着您有一个指向指针数组的指针,而不是另一个指针本身。所以本质上,您需要使用以下内容args_mem_loc作为指向指针的指针传入:

&args_mem_loc[0]

或者

&args_mem_loc[1]

然后,您将有一个指针(来自 void*)指向另一个指针(数组的每个插槽中的内容)。

于 2013-08-21T18:05:05.120 回答