请耐心听我说,因为我几乎不知道我在说什么。我正在尝试从 PGM 文件中读取数据(不包括 header )。我有一个函数(read_data),它接受双指针(char** data)作为参数。
在函数中,我可以将数据放入数组(arr)中,但我的问题是将指针(**data)分配给该数组。这是迄今为止我的代码:
read_data(char* file, char** data) {
FILE *fp = fopen(file, "rb");
char type[3], dump;
int i =0, data_length;
int w, h; // width & height
fgets(type, sizeof(type), fp);
fscanf(fp, "%d", &w);
fscanf(fp, "%d", &h);
if (strcmp(type, "P5 ")) {
data_length = w * h;
}
else {
data_length = (w * h) * 3;
} // this is to work out the size of the array (how many bits of data are in the file)
char arr[data_length];
while ((dump = fgetc(fp)) != '\n'); // just to skip the header
for (i; i < data_length; i++) {
arr[i] = fgetc(fp);
}
data = &arr; // <--- The problem
fclose(fp);
return data_length;
}
main () {
int data_length;
char **data = malloc(sizeof(int*)*data_length);
read_data("file.pgm",data);
}
希望这是可读的。谢谢。
最佳答案
您正在组合两个不同的问题:文件 I/O 和指针处理。由于真正的问题是指针处理,让我们使用一个更简单的示例。首先,一个可以创建和填充 char
数组的函数:
#include <stdio.h>
#include <string.h>
void foo()
{
char arr[6];
strcpy(arr, "hello");
printf("%s\n", arr);
}
到目前为止,一切都很好。 (从这里开始,我将省略 #include
指令。)但这是堆栈上的一个数组,因此当控制权传出函数时,它又会变成荒野。我们想要在堆上进行动态分配:
void foo()
{
char *arr = malloc(6*sizeof(char));
strcpy(arr, "hello");
printf("%s\n", arr);
}
(注意:在你的问题中,你在函数外部声明了数组,但这意味着你必须在不知道它应该是多少长度的情况下这样做,这似乎不是你想要的.这是一种更简洁的方法,如果您确实想在外部声明数组,只需稍加修改即可实现。)
现在关于指针。很容易将该数组的地址(即分配给 arr
的值)分配给另一个指针:
char *p;
p = arr;
但我们不想将该值赋给函数中的某个局部指针变量;我们希望将其分配给返回到调用函数的代码范围内的指针值。使用普通变量执行此操作的方法是使用指向该变量的指针:
void bar(int *k)
{
*k = 5;
}
...
int n;
bar(&n);
...
所以我们对这个指针变量做同样的事情:
void foo(char **p)
{
char *arr = malloc(6*sizeof(char));
strcpy(arr, "hello");
*p = arr;
}
int main()
{
char *z;
foo(&z);
printf("%s\n", z);
}
(我们甚至可以取消 arr
,但让我们慢慢来。)
一旦明确了这一点,您就可以将其拼接到处理文件 I/O 的代码中。请记住,始终单独开发新功能。
关于c - 指向一维数组的双指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25636131/