C - 使用 fgets() 读取文件的最后一行时出现段错误



我正在解决数据结构作业的编码问题,在使用 fgets(( 读取文本文件的最后一行时,我的解决方案的一部分一直给我一个segfault: 11

我已经在StackOverflow中搜索了一段时间,但找不到我遇到的相同错误。我已经尝试了很多方法来解决问题,但我无法弄清楚到底出了什么问题。

int main() {
    **S = func();
    free(S);
    return 0;
}
char** func() {
    FILE *fStrings = fopen("file.txt", "r");
    if (fStrings == NULL) printf("Error opening 'file.txt'n")
    int length = fileLength("file.txt");  // This returns just the number of lines in a file, works as intended.
    char **strings = (char **)malloc(200 * length * sizeof(char));
    f(length, (char (*)[200])strings, *fStrings);
    // some code using the data modified by f()
    fclose(fStrings);
    return strings;
}
void f(int length, char strings[][200], FILE *fStrings) {
    int i;
    for (i = 0; i <= length; i++) {
        printf("i = %dn", i);  // debug
        fgets(strings[i], 200, fStrings);  // Here's the problem
        printf("string = %sn", strings[i]);  // debug
    }
}

上面的代码有 2 个调试行,用于查看错误发生的确切位置。该函数使用正确的参数调用,其中length是数组中的字符串数量,strings是字符串数组,fStrings包含所述字符串的文件。

尝试读取文本文件的最后一行时发生segfault。任何帮助将不胜感激。

编辑:更改了代码块以包含我的代码的更好版本,以防它更容易理解。还包括正确的库。

我认为你的代码的主要问题是这一行

for (i = 0; i <= length; i++) {

由于<=它将循环"长度 + 1"次,但您只为"长度"时间分配了内存。将其更改为:

for (i = 0; i < length; i++) {

你的分配很奇怪。您应该使用指向 1D 数组的指针分配 2D 数组,即:

char (*strings)[200] = malloc(length * sizeof *strings)

然后,您可以在没有任何投射的情况下进行通话。

也刚刚注意到这行:

f(length, (char (*)[200])strings, *fStrings);
                                  ^
                                  notice

我认为你不想在fStrings面前*(它甚至不应该用*编译(

使用正确的分配(如上所述(,调用应该是:

f(length, strings, fStrings);

相关内容

  • 没有找到相关文章