Forum: Compiler & IDEs mallo und free


von Mr. Schmitt (Gast)


Lesenswert?

Hallo Zusammen,
1
int *i = (int*) malloc(sizeof(int) * 5);
2
...
3
...
4
...
5
free(i);
Meine Frage ist.
Woher weisst free() wie viel Speicher malloc() allokiert hat, das free() 
frei gibt?

von Karl H. (kbuchegg)


Lesenswert?

Mr. Schmitt schrieb:
> Hallo Zusammen,
>
>
1
> int *i = (int*) malloc(sizeof(int) * 5);
2
> ...
3
> ...
4
> ...
5
> free(i);
6
>
> Meine Frage ist.
> Woher weisst free() wie viel Speicher malloc() allokiert hat, das free()
> frei gibt?

Aus der Speicherverwaltung.
malloc gibt ja nicht einfach nur einen Pointer raus, sondern es muss 
selbstverständlich auch darüber Buch führen welchen Speicher es 
rausgegeben hat und wie groß der war. Das muss es schon alleine 
deswegen, weil es ja keine überlappenden Speicherbereiche rausrücken 
darf wenn du 5 mal malloc ohne einen free dazwischen aufrufst.

Hinter malloc und free steckt noch ein ganzer Rattenschwanz an 
Funktionalität. Einer der Gründe warum man malloc auf den kleinen µC 
nicht so gerne einsetzt.

von Emperor_L0ser (Gast)


Lesenswert?

Zum Angefordertem Speicher wird noch irgendwo zusätzlich Speicher 
reserviert.

Ein Beispiel wäre hier die avr-libc, dort ist das ganze sehr einfach und 
effizient Implementiert. Die Zwei Bytes vor dem Pointer geben die Größe 
des Speicherbereiches an:

http://www.nongnu.org/avr-libc/user-manual/malloc.html

Absatz: Implementation details

von Jörg W. (dl8dtl) (Moderator) Benutzerseite


Lesenswert?

Karl Heinz Buchegger schrieb:
> Hinter malloc und free steckt noch ein ganzer Rattenschwanz an
> Funktionalität. Einer der Gründe warum man malloc auf den kleinen µC
> nicht so gerne einsetzt.

Naja, der "Rattenschwanz" in der avr-libc ist gerade mal ein
vorangestelltes Feld mit der Länge.  Der Implementierungsaufwand
hält sich in erträglichen Grenzen, es werden keine weiteren
Optimierungsversuche (wie Allokation in ganzen 2^N-Blöcken oder
dergleichen) gemacht.  War auch einer der Gründe, warum ich das
damals für die avr-libc von Grund auf neu geschrieben habe, statt
eine existierende Implementierung zu nehmen (die zu dieser Zeit
dann alle schon an creeping featurism gelitten haben).

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.