[英]How can I declare and unpack an array of pairs of void pointers?
我想写一个 function ,它需要一个void*
“对”数组 - 每个都是一对指向某物的指针。 每对中的第一个元素将是一个字符串,第二个元素将是指向其他内容的指针。
我希望传递到 function 的数组声明如下:
<what type?> argument = {
{ "some string", <some pointer>},
{ "some other string", <some other pointer>},
// ... etc
NULL // To signal ending
}
function(argument);
在function
内部,我想遍历数组,访问每个“对”,将“对”的成员转换为它们各自的类型(我知道)并利用这些成员。
我遇到了一些麻烦。 起初,我尝试将参数声明为void* thing[][]
。 认为它是一个由void
指针组成的 arrays 数组。
但是,简单地尝试访问此类数组中的索引会给我错误: expression must be a pointer to a complete object type
。
阅读 SO 我意识到编译器正在考虑我正在尝试取消引用void*
。 但我认为在这样的数组上执行a[0]
将访问数组中的第一个“对”,这应该取消引用void**
- 这是合法的。 我错了吗?
关于这个问题,go 的正确方法是什么,就数组的类型、它的初始化和迭代期间解包数组的方式而言?
你想要void *argument[][2] = { /*... */ };
. 您有一个未指定大小的数组,其元素是固定大小为 2 的 arrays,其元素是指向void
的指针。 您最初的编译器错误是因为当您有多个方括号时,只有第一组可以为空,因此添加2
修复了它。
顺便说一句,它可以作为指针衰减,在这种情况下它将是void *(*argument)[2]
。
请注意,您的哨兵NULL
并没有达到您的预期,因为它位于 arrays 和 arrays 的数组中,并不是完全的指针。 请注意此警告:
warning: suggest braces around initialization of subobject [-Wmissing-braces]
NULL // To signal ending
^~~~
{ }
这是一个使用该类型的示例程序:
#include <stdio.h>
void *g[][2] = {
{ "some string", (void*)0x1234},
{ "some other string", (void*)0x5678},
{ "some third string", (void*)0x9abc},
// ... etc
{NULL} // To signal ending
};
void print_things(void *argument[][2]) {
for(int i = 0; argument[i][0] /* using just argument[i] instead of argument[i][0] here would not work as intended */; ++i) {
printf("%s %p\n", (char*)argument[i][0], argument[i][1]);
}
}
int main(void) {
print_things(g);
return 0;
}
最后一点,我想说使用自定义struct
你的生活可能会更简单:
#include <stdio.h>
struct pair {
char *str;
void *ptr;
} g[] = {
{ "some string", (void*)0x1234},
{ "some other string", (void*)0x5678},
{ "some third string", (void*)0x9abc},
// ... etc
{NULL, NULL} // To signal ending
};
void print_things(struct pair argument[]) {
for(int i = 0; argument[i].str; ++i) {
printf("%s %p\n", argument[i].str, argument[i].ptr);
}
}
int main(void) {
print_things(g);
return 0;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.