指向1D数组的双指针

时间:2014-09-03 04:15:23

标签: c arrays pointers malloc

请耐心等待,因为我几乎不知道我在谈论什么。我试图从PGM文件中读取数据(不包括标题)。我有一个函数(read_data)接受一个双指针(char **数据)作为参数。

在函数中,我能够将数据放入数组(arr),但我的问题是将该指针(**数据)分配给该数组。这是我到目前为止的代码:

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);

}

希望这是可读的。感谢。

2 个答案:

答案 0 :(得分:2)

您正在组合两个不同的问题:文件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的代码。请记住,始终要孤立地开发新功能。

答案 1 :(得分:-1)

试试这个

int n = 0;

while(condition)
    nextchar = fgetc(filepointer);
    (*image_data)[n]= nextchar;
    // or (*data)[n]= nextchar;
    n++;