我正在解决数据结构作业的编码问题,在使用 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);