无法将 return 中的“char (*)[1024]”转换为“char*”

Cannot convert ‘char (*)[1024]’ to ‘char*’ in return

我想逐行读取一个简单的文件并将内容保存到一个数组中。如果我编译源代码,我会得到这个错误:

test.C: In function ‘char* read_file(int, int, const char*)’:
test.C:14:11: error: cannot convert ‘char (*)[1024]’ to ‘char*’ in return
    return words;
           ^

这是什么意思?为什么我不能 return 二维数组的指针?这是源代码。

#include <stdio.h>
#include <string.h>

char * read_file(int buf, int size, const char *fname){
   char words[size][buf];
   FILE *fptr = NULL; 
   int idx = 0;

   fptr = fopen(fname, "r");
   while(fgets(words[idx], buf, fptr)) {
      words[idx][strlen(words[idx]) - 1] = '[=12=]';
      idx++;
   }
   return words;
}

int main(void) {
   char * words;
   words = read_file(1024, 100, "text.txt");
   int i;
   for(i = 0; i < 100; ++i)
        printf("%s\n", words[i]);
}

你实际上有两个问题:第一个是关于错误的。 char 的数组与指向 char 的指针不同。随着数组衰减为指针,char 数组的数组等效于指向 char 数组的指针,或者在您的特定情况下为 char (*)[buf]

第二个问题更糟,那就是你试图 return 一个指向局部变量的指针。一旦函数returns,局部变量就超出作用域,基本不复存在。所以一旦函数 returns 指针不再有效。

由于您使用的是可变长度数组,因此您拥有的一种解决方案是动态分配数组,作为指向 char 的指针,即 char ** 和 return .另一种解决方案是将数组作为参数传递。


在我看来,最简单的解决方案是在 main 函数中声明数组并将其传递给函数,这样您就不必为指针和动态分配而烦恼,更具体地说是释放稍后的记忆。

像这样:

#define STRING_COUNT  100    // Number of strings
#define STRING_SIZE   1024   // Size of each string

// Open and read the file, returns the number of "words" read
size_t read_file(const char *filename, char (*words)[STRING_SIZE])
{
    // Implement the function...
    // Don't forget to return the number of "words", actually lines, you read
}

int main(void)
{
    char words[STRING_COUNT][STRING_SIZE];
    size_t number_words = read_file("test.txt", words);

    // Use the "words" here...
    ...

    return 0;
}