Cpp指针和数组

Cpp pointers and arrays

本文关键字:数组 指针 Cpp      更新时间:2023-10-16

你能不能帮我理解一下?

我有一个函数需要"char ***argv";

据我所知,它是:指向char指针数组的指针

这样的:" char * arr [] "?

char xx1 = '1';
char xx2 = '2';
char *argv[] = {&xx1,&xx2};

然后我调用我的函数gtk_init (&argc, &argv);

And get error:

main.cpp:43:31: error: cannot convert ‘char* (*)[2]’ to ‘char***’ for argument ‘2’ to ‘void gtk_init(int*, char***)’

谢谢你的帮助。

char***是"指向char的指针指向指针的指针"。根本不涉及数组。你的argv是一个"指向char的2个指针的数组"。在某些情况下,你的数组名称argv将衰减为指向其第一个元素的指针-该指针的类型将为char**,或"指向char的指针的指针"。

当你做&argv时,你会得到一个char* (*)[2],或者一个"指向2个指向char的指针数组"。这不是你想要的。这是因为你取的是数组的地址,而不是指针的地址。

此外,您将遇到这样一个问题,即您在argv中的指针只是指向单个char s,而不是指向以空结束的字符串。gtk_init几乎肯定会期望以空结尾的字符串。

那么你能做什么呢?试试这个:

char xx1[] = "1"; // Now these are null-terminated strings
char xx2[] = "2";
char* argv[] = {xx1, xx2};
char** argvp = argv; // Use the fact that the array will decay
gtk_init(&argc, &argv); // &argv will now be a char***

为字符串使用数组的原因是我们需要char类型为非const,但是不赞成使用char* str = "hello";类型的声明——必须是const char*。然而,通过使用数组,字符串字面值的内容被复制到数组中,因此我们可以自由地将其设置为非const

gtk_init实际上只是希望您将主函数的argcargv参数传递给它,如下所示:

int main(int argc, char* argv[])
{
  gtk_init(&argc, &argv);
  // ...
}

你现在可能会问"但是为什么现在允许&argv ?"argv与问题中的类型相同!我们为什么不重新得到一个指向数组的指针呢?"实际上,argv不是同一类型,尽管它看起来很像。当你定义一个接受数组参数的函数时,它实际上被转换成一个指针。因此,main的定义相当于:

int main(int argc, char** argv);

所以当我们执行&argv时,我们完全没问题,因为它给了我们一个char***

正如@OmnipotentEntity在评论中所说-你最好有一个很好的理由不将main的参数传递给gtk_init