Ich habe diese Funktion geschrieben, um eine Zeile aus einer Datei zu lesen:
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;
}
Die Funktion liest die Datei korrekt und mit printf sehe ich, dass die constLine-Zeichenfolge auch korrekt gelesen wurde.
Wenn ich jedoch die Funktion zB so benutze:
while (!feof(myFile)) {
const char *line = readLine(myFile);
printf("%s\n", line);
}
printf gibt Kauderwelsch aus. Warum?
getline()
ein Teil von POSIX 2008 ist. Es kann POSIX-ähnliche Plattformen ohne POSIX 2008 geben, insbesondere wenn sie den Rest von POSIX 2008 nicht unterstützen, aber in der Welt der POSIX-Systeme getline()
heutzutage ziemlich portabel sind.
fgets
anstelle vonfgetc
. Sie lesen Zeichen für Zeichen anstatt Zeile für Zeile.