Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Dispose, Free, FreeAndNil oder doch Destroy ? (https://www.delphipraxis.net/215988-dispose-free-freeandnil-oder-doch-destroy.html)

paule32.jk 8. Okt 2024 13:55

Dispose, Free, FreeAndNil oder doch Destroy ?
 
Hallo.

Beim Umgang mit Objekten und Klassen habe ich viele Codestellen gesehen, bei denen
- Dispose,
- Free, und
- FreeAndNil

verwendet werden.
Letzteres wurde ja in einer frühen Version von Delphi ja noch nicht eingeführt oder verwendet und man musste sich das dann selbst zusammen klabustern...

jetzt aber habe ich Code gesehen, bei dem:
- Destroy

aufgerufen wird und frage mich nun: "Welche Funktion ist denn nun die richtige Wahl, einen Objekt/Klasse "Speicherbereich" zu bereinigen ?
Weil, Destroy kommt mir sehr nahe an das TForm Event OnCreate und OnDestroy.

dummzeuch 8. Okt 2024 14:04

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
Dispose funktioniert nicht mit Klassen sondern nur mit Pointern oder den guten alten object-Datentypen aus der Turbo Pascal-Zeit (werden die von aktuellen Delphis überhaupt noch unterstützt?)
Delphi-Quellcode:
Dispose(ObjPtr, Done);


Destroy gibt den Speicher der Klasse nicht frei.

Ob Free oder FreeAndNil ist ziemlich Geschmacksache. FreeAndNil ruft intern Free auf und setzt zusätzlich die übergebene Referenz auf NIL (aber evtl. andere Referenzen behalten den alten Wert zeigen danach also auf eine ungültiges Instanz).

DeddyH 8. Okt 2024 14:11

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
Bist Du Dir da sicher? Dispose war doch diese unglaublich tolle Idee, um plattformübergreifend Speicher freizugeben. Und Free prüft lediglich sich selbst gegen nil, bevor es intern Destroy aufruft.

Uwe Raabe 8. Okt 2024 14:19

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
Zitat:

Zitat von DeddyH (Beitrag 1541942)
Dispose war doch diese unglaublich tolle Idee, um plattformübergreifend Speicher freizugeben.

Das war DisposeOf.

Zitat:

Zitat von dummzeuch (Beitrag 1541941)
Destroy gibt den Speicher der Klasse nicht frei.

Solange Destroy ein
Delphi-Quellcode:
destructor
ist schon.

DeddyH 8. Okt 2024 14:21

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
Danke für die Richtigstellung, hab ich verwechselt.

himitsu 8. Okt 2024 14:45

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
Destroy gibt immer frei,
aber es sollte "normal" eigentlich NIE direkt aufgerufen werden. (wäre schön, wenn es standardmäßig protected wäre)

Free gibt frei ... bei NIL knallt es aber nicht, da es einem
Delphi-Quellcode:
if Assiged(obj) then obj.Destroy;
entspricht.

FreeAndNil müsste eigentlich NilAndFree heißen,
denn es entspricht keinem
Delphi-Quellcode:
obj.Free;
obj := nil;
sondern einem
Delphi-Quellcode:
obj := nil;
obj.Free;

// ähhhh, ich meine natürlich

tmp := obj;
obj := nil;
tmp.Free;
Es setzt also immer die Variable auf NIL, selbst wenn es im Free/Destroy knallt.

himitsu 8. Okt 2024 14:51

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
Zitat:

Zitat von DeddyH (Beitrag 1541942)
Dispose war doch diese unglaublich tolle Idee, Und Free prüft lediglich sich selbst gegen nil, bevor es intern Destroy aufruft.

Bei aktivem ARC machte Free einfach garnichts. :freak:

Drum mußte man DisposeOf nutzen, wenn man wirklich "jetzt" freigeben wollte.
Und jetzt einfach immer DisposeOf überall im Code zu nutzen, um den selben Code auch ohne ARC nutzen zu können ... neee, das ging/geht natürlich auch nicht. :angle2:

Joar, die geilste Idee ever ... anstatt das Free Destroy gleich richtig zu implementieren.
Fast eine genauso hirnrissige Idee wie ForceQueue, anstatt das Queue zu reparieren, damit es immer das macht, sonach es klingt.

Rollo62 8. Okt 2024 14:57

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
Ohne das leidige FreeAndNil Thema anstossen zu wollen, hier ein bischen Lesestoff aus verschiedenen Äonen: :roll:
https://en.delphipraxis.net/topic/70...#comment-60109
https://wiert.me/2024/06/26/delphi-h...t-lies-to-you/
https://web.archive.org/web/20061101...edy/freeandnil
https://web.archive.org/web/20120118...10/02/16/38916
https://web.archive.org/web/20120118...10/02/05/38910
https://dalijap.blogspot.com/2022/07...ad-safety.html

paule32.jk 8. Okt 2024 14:57

AW: Dispose, Free, FreeAndNil oder doch Destroy ?
 
ist ja "alles" anders als "lustig" diese "Programmier(eier), die dann schlüpfriche Sachen wie Buks erwachen lachen...".
ist ja kein Wunder, warum in der Programmierenden IT der Nachwuchs fehlt (weil keiner mehr sich das antun will, und von Null anfangen möchte - gut macht man ja eigentlich auch nicht. Aber manchmal ist nen total Black-Green-Ausfall wohl das beste mal alles von neu zu beginnen. Aber dann hat man keine Changen auf dem Markt, der "ältere" Anwendungen beherbergt mit seiner wilden Scharr an Fullstackern, die dann das sinkende Schiff auspumpen sollen...

oh man, was für eine verrückte Welt...


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:39 Uhr.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz