Was ist da falsch?
-
-
ich würd mal sagen ohne -ansi kompilieren. oder
char* line;
...
line = (char*) malloc(sizeof(char)*MAX_LENGTH+1); -
ich würd mal sagen ohne -ansi kompilieren.
Ohne -ansi ist es bissl Problem weil die Richtlinien für Sysprog sind leider fest vorgegeben:
-
Das ändern, was der Compiler bemängelt: Variablendeklarationen und Code sind vermischt. In ANSI C müssen alle Variablendeklarationen für einen Block am Beginn des Blocks erfolgen, erst dann darf eigentlicher Code (Funktionsaufrufe, Zuweisungen etc.) kommen.
Bei der Variante von ChristophM sollte man free() nicht vergessen.
-
-
Die Warnung bezieht sich auf die Reihenfolge von allen Deklarationen und allen sonstigen Statements in der gesamten Funktion. Entweder postest du also die ganze Funktion oder schaust selber drauf, daß zuerst nur Deklarationen kommen und dann nur Nichtdeklarationen.
Und Arrays kleiner konstanter Länge mit malloc anlegen ist total überflüssig. Total überflüssig ist übrigens auch der Cast (char *), der sollte weg.
-
Habs geloest mit der Reihenfolge, zuerst Initialisierungen und erst dann Zuweisungen.
Jetzt mitmachen!
Sie haben noch kein Benutzerkonto auf unserer Seite? Registrieren Sie sich kostenlos und nehmen Sie an unserer Community teil!