Я написал эту функцию для чтения строки из файла:
const char *readLine(FILE *file) {
if (file == NULL) {
printf("Error: file pointer is null.");
exit(1);
}
int maximumLineLength = 128;
char *lineBuffer = (char *)malloc(sizeof(char) * maximumLineLength);
if (lineBuffer == NULL) {
printf("Error allocating memory for line buffer.");
exit(1);
}
char ch = getc(file);
int count = 0;
while ((ch != '\n') && (ch != EOF)) {
if (count == maximumLineLength) {
maximumLineLength += 128;
lineBuffer = realloc(lineBuffer, maximumLineLength);
if (lineBuffer == NULL) {
printf("Error reallocating space for line buffer.");
exit(1);
}
}
lineBuffer[count] = ch;
count++;
ch = getc(file);
}
lineBuffer[count] = '\0';
char line[count + 1];
strncpy(line, lineBuffer, (count + 1));
free(lineBuffer);
const char *constLine = line;
return constLine;
}
Функция правильно читает файл, и с помощью printf я вижу, что строка constLine также правильно прочитана.
Однако, если я использую функцию, например, так:
while (!feof(myFile)) {
const char *line = readLine(myFile);
printf("%s\n", line);
}
printf выводит бред. Зачем?
getline()
это часть POSIX 2008. Могут существовать POSIX-подобные платформы без него, особенно если они не поддерживают остальную часть POSIX 2008, но в мире систем POSIX в getline()
наши дни довольно переносимы.
fgets
вместоfgetc
. Вы читаете символ за символом вместо строки за строкой.