Was ist da falsch?
-
NonSense -
3. Mai 2007 um 00:43 -
Unerledigt
das Informatik-Forum geht in den Archivmodus, genaue Informationen kann man der entsprechenden Ankündigung entnehmen. Als Dankeschön für die Treue bekommt man von uns einen Gutscheincode (informatikforum30) womit man bei netzliving.de 30% auf das erste Jahr sparen kann. (Genaue Infos sind ebenfalls in der Ankündigung)
Vielen Dank für die Treue und das Verständnis!
-
-
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.
-
Maximilian Rupp
27. Dezember 2024 um 12:05 Hat das Thema aus dem Forum Programmieren nach Entwicklung verschoben.