我目前正在努力学习C,我遇到了一个我无法解决的问题.
考虑:
#include#include #include #define ELEMENTS 5 void make(char **array, int *array_size) { int i; char *t = "Hello, World!"; array = malloc(ELEMENTS * sizeof(char *)); for (i = 0; i < ELEMENTS; ++i) { array[i] = malloc(strlen(t) + 1 * sizeof(char)); array[i] = strdup(t); } } int main(int argc, char **argv) { char **array; int size; int i; make(array, &size); for (i = 0; i < size; ++i) { printf("%s\n", array[i]); } return 0; }
我不知道为什么上面的内容在创建之后无法回读数组的内容.我花了一个小时的时间试图理解它为什么会失败但却空手而归.毫无疑问,这是微不足道的.
干杯,
您需要将"array"的地址传递给函数.也就是说,你需要char***.这是因为您需要通过为其分配内存来更改数组的值.
编辑:只是为了使它更完整,在函数声明中你需要有类似的东西
void make(char ***array, int *array_size)
然后你需要使用它来调用它
make(&array, &size);
在函数make里面,分配内存
*array = malloc(ELEMENTS * sizeof(char *));
并相应地改变其他地方.
另外,正如kauppi指出的那样,strdup会为你分配内存,所以你不需要在每个字符串上做malloc.
这是工作代码:
#include#include #include #define ELEMENTS 5 void make(char ***array) { char *t = "Hello, World!"; *array = malloc(ELEMENTS * sizeof(char *)); int i; for (i = 0; i < ELEMENTS; ++i) { (*array)[i] = strdup(t); } } int main(int argc, char **argv) { char **array; make(&array); int i; for (i = 0; i < ELEMENTS; ++i) { printf("%s\n", array[i]); free(array[i]); } free(array); return 0; }
正如另一个发布的那样 - 有未使用的大小,并且strdup自己分配内存,之后释放内存是很好的...