[英]array of pointers to a char array
gcc 4.4.4 c89
但是,我在尝试展示所有动物时遇到了问题。
我有以下代码。
我正在尝试显示数组中的所有动物。 所以我有3个指向char *的指针数组。 然后是一个指向这些数据集的指针数组。
我试图控制内部循环以检查-1和外部的NULL。
void initialize_char_array()
{
char *data_set1[] = {"dog", "cat", "bee", NULL};
char *data_set2[] = {"rabbit", "ant", "snake", "rat", NULL};
char *data_set3[] = {"cow", "lizard", "beaver", "bat", "hedgehog", NULL};
char *ptr_char[] = {*data_set1, *data_set2, *data_set3, NULL};
display_char_array(ptr_char);
}
void display_char_array(char **ptr_char)
{
size_t inner = 0, outer = 0;
for(outer = 0; ptr_char[outer] != NULL; outer++) {
for(inner = 0; *ptr_char[inner] != -1; inner++) {
printf("data [ %s ]\n", ptr_char[outer][inner]);
}
}
}
非常感谢您的任何建议,
*data_set1
与data_set1[0]
相同。 这是您尝试做的固定版本。 恕我直言,这是您使用的问题:循环中的索引变量或指针迭代器,显然编译器将生成完全相同的机器代码。
// type of ptr_char changed
void display_char_array(char **ptr_char[])
{
size_t inner = 0, outer = 0;
for(outer = 0; ptr_char[outer] != NULL; outer++) {
// check for NULL in inner loop!
for(inner = 0; ptr_char[outer][inner] != NULL; inner++) {
printf("data [ %s ]\n", ptr_char[outer][inner]);
}
}
}
void initialize_char_array()
{
char *data_set1[] = {"dog", "cat", "bee", NULL};
char *data_set2[] = {"rabbit", "ant", "snake", "rat", NULL};
char *data_set3[] = {"cow", "lizard", "beaver", "bat", "hedgehog", NULL};
// fixed
char **ptr_char[] = {data_set1, data_set2, data_set3, NULL};
display_char_array(ptr_char);
}
如果您使用initialize_char_array
函数初始化ptr_char
数组的方式,您将永远无法显示所有动物。 您将只能显示三个列表中的每个列表的第一个。 如果您希望能够访问所有动物,则应首先将ptr_char
定义为指向char指针的指针数组: char **ptr_char[]
。
然后,显示函数应将类型为char ***
的参数作为参数。 是的,这是3个间接级别。 然后,不要使用size_t
变量在数组中循环,使用char **
和char *
。
遍历每个数组的类型可能会有所帮助。 请记住,在大多数情况下,数组表达式的类型会从N-element array of T
隐式转换(衰减) pointer to T
或T *
1的 pointer to T
。 在data_set1,data_set2和data_set3的情况下, T
为char *
,因此表达式data_set1
从4-element array of char *
隐式转换pointer to char *
或char **
pointer to char *
。 如下表所示,其他两个数组也是如此:
Array Type Decays to ----- ---- --------- data_set1 char *[4] char ** data_set2 char *[5] char ** data_set3 char *[6] char **
如果您要创建这些表达式的数组(这似乎是您想做的),则需要使用数组声明
char **ptr_char[] = {data_set1, data_set2, data_set3, NULL};
这给了我们
Array Type Decays to ----- ---- --------- ptr_char char **[4] char ***
因此,ptr_char是一个指向char或char **ptr_char[4]
的指针的指针数组。 当将ptr_char
作为参数传递给显示函数时,它将再次从4-element array of char **
类型4-element array of char **
隐式转换pointer to char **
或char ***
pointer to char **
。
sizeof
或&
(地址)运算符的操作数,或者表达式是用于初始化声明中另一个数组的字符串文字。
在尝试(未成功)调试您编写的版本后,我重新编写了您的程序:
#include <stdio.h>
void display_char_array(char ***ptr_char)
{
for ( ; *ptr_char != NULL; ptr_char++ ) {
char **data_set;
for ( data_set = *ptr_char; *data_set != NULL; data_set++ ) {
printf("data [ %s ]\n", *data_set);
}
}
}
void initialize_char_array()
{
char *data_set1[] = {"dog", "cat", "bee", NULL};
char *data_set2[] = {"rabbit", "ant", "snake", "rat", NULL};
char *data_set3[] = {"cow", "lizard", "beaver", "bat", "hedgehog", NULL};
char **ptr_char[] = { data_set1, data_set2, data_set3, NULL };
display_char_array(ptr_char);
}
int main( void )
{
initialize_char_array();
return 0;
}
您的版本将出现段错误,并且指针的使用非常令人困惑!
错误是仅使用data_set中的第一个元素初始化ptr_char ?,请参见下文:
void initialize_char_array()
{
char *data_set1[] = {"dog", "cat", "bee", NULL};
char *data_set2[] = {"rabbit", "ant", "snake", "rat", NULL};
char *data_set3[] = {"cow", "lizard", "beaver", "bat", "hedgehog", NULL};
char **ptr_char[] = {data_set1, data_set2, data_set3, NULL};
display_char_array(ptr_char);
}
void display_char_array(char ***p)
{
while( *p )
{
while( **p )
{
puts(**p);
++*p;
}
++p;
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.