www.mikrocontroller.net

Forum: GCC kurze gcc Verständnisfrage


Important announcement: there is an English version of this forum on EmbDev.net. Posts you create there will be displayed on Mikrocontroller.net and EmbDev.net.
Autor: lex (Gast)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Hallo,

hätte eine kurze Frage zur Arbeitsweise des gcc, bzw auch anderen C 
Compilern.

Folgendes kurzes Codesegment:
char string[6];
printf("%i", sizeof(string));

liefert natürlich Ausgabe 6.

Aber woher weis die Software die Länge des Strings (oder eines Arrays)?

Reiche ich den String an eine Funktion weiter
doSomething(string);

mit dem Prototyp
void doSomething(char *);

und lass mir dort die sizeof ausgeben, kommt irgendwas raus.

Anhand des '/0' kann sizeof die Länge ja nicht ermitteln, da der 
komplette String ja normalerweise zu NULL initialisiert wird.

Kann mich jemand aufklären?

Viele Grüße,
lex

Autor: ich (Gast)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Die Software weiß das weil es der Compiler reingeschrieben hat, Zitat 
Wikipedia:
"In most cases, sizeof is a compile-time operator, which means that 
during compilation sizeof expressions get replaced by constant 
result-values."

Autor: lex (Gast)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Danke dir, erklärt natürlich einiges.

Das macht es meiner Funktion (die einen String übergeben bekommt) aber 
unmöglich festzustellen, wieviel sie reinschreiben darf.

Will ich sichergehen, dass der String leer ist kann ich ihn auch nicht 
einfach mit NULL füllen.

Wie löst man sowas am geschicktesten?
Zweiten Parameter für die Länge?

Oder hoffen dass der Aufrufer genug Platz reserviert hat?

Autor: Joachim Drechsel (Firma: JDCC) (scheppertreiber)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
lex schrieb:
> char string[6];

Das Array hat die Größe 6 Byte.

> doSomething(char *);

Der Zeiger hat (iA) die Größe 2 Byte (da steht char*).
Es sind unterschiedliche Datentypen.

Autor: ich (Gast)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
> Wie löst man sowas am geschicktesten?
> Zweiten Parameter für die Länge?
genau so!

> Oder hoffen dass der Aufrufer genug Platz reserviert hat?
auf keinen Fall, das ist ne riesen Sicherheitslücke.

Autor: Joachim Drechsel (Firma: JDCC) (scheppertreiber)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
ich schrieb:
> auf keinen Fall, das ist ne riesen Sicherheitslücke.

Das ist dann PHP ;)

Autor: Rolf Magnus (rmagnus)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
lex schrieb:
> Zweiten Parameter für die Länge?

Das ist ein gängiger Weg. Die Funktion muß die Länge auf irgendeine 
Weise kennen.


Joachim Drechsel schrieb:
> lex schrieb:
>> char string[6];
>
> Das Array hat die Größe 6 Byte.
>
>> doSomething(char *);
>
> Der Zeiger hat (iA) die Größe 2 Byte (da steht char*).

Naja, 2 gibt's eigentlich haupstächlich auf ganz kleinen µCs und alten 
DOS-Rechnern. 4 und 8 sind heute doch deutlich häufiger anzutreffen.

> Es sind unterschiedliche Datentypen.

Und zwar auch dann, wenn man schreiben würde:
doSomething(char string[6]);
Die Defintion des Parameters sieht zwar exakt gleich aus wie die 
Variable oben, aber trotzdem ist der Funktiosnparameter kein Array, 
sondern immer noch ein Zeiger auf char. Man kann an Funktionen keine 
Arrays direkt übergeben. Man übergibt nur einen Zeiger, und dem sieht 
man die Größe des Arrays nicht mehr an. Also muß diese Größe auf anderem 
Weg mitgeteilt werden.

Autor: Joachim Drechsel (Firma: JDCC) (scheppertreiber)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Rolf Magnus schrieb:
> Naja, 2 gibt's eigentlich haupstächlich auf ganz kleinen µCs und alten
> DOS-Rechnern. 4 und 8 sind heute doch deutlich häufiger anzutreffen.

Achwas. Hier ist doch Mikrocontroller :-)))))

(hast ja recht, ich wollte nur das Auge für den Unterschied schärfen)

Autor: Ralf G. (ralg)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Könnte man auch sowas machen?
char* doSomthing()
{
 static *str=NULL;
// prüfen, ob str!=NULL -> Speicher freigeben
// neuen Speicher anlegen; nach was für Regeln auch immer
// String füllen
 return str;
}

// Programmteil
char *strTmp,string[6];
strTmp=doSomthing();
strcpy(string,strTmp);

// oder sogar bei völlig variablen Rückgabelängen
char *strTmp,*string;
strTmp=doSomthing();
// Speicher für 'string' anmelden mit Größe 'strlen(strTmp)+1'
// danach:
strcpy(string,strTmp);


Autor: Joachim Drechsel (Firma: JDCC) (scheppertreiber)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Ralf G. schrieb:
> char* doSomthing()
> {
>  static *str=NULL;
> // prüfen, ob str!=NULL -> Speicher freigeben
> // neuen Speicher anlegen; nach was für Regeln auch immer
> // String füllen
>  return str;
> }

static char *str;

Die Funktion soll ja einen char-Pointer zurückgegeben.

Autor: Ralf G. (ralg)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Joachim Drechsel schrieb:
> static char *str;
>
> Die Funktion soll ja einen char-Pointer zurückgegeben.

Ja, geträumt! :(

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel




Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder GIF-Format hochladen.
Siehe Bildformate
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken erkennst du die Nutzungsbedingungen an.

webmaster@mikrocontroller.netImpressumNutzungsbedingungenWerbung auf Mikrocontroller.net