Delphi-PRAXiS
Seite 2 von 4     12 34      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Verständnisfrage Assigned vs nil (https://www.delphipraxis.net/202710-verstaendnisfrage-assigned-vs-nil.html)

bcvs 30. Nov 2019 14:33

AW: Verständnisfrage Assigned vs nil
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1452510)
Anders sieht es z.B. bei Events aus. Man kann eine Event-Variable (so wie jeden Methodenzeiger) nicht auf nil abfragen.

Wieso nicht? Ich hatte immer gedacht, das wäre auch da gleichwertig. (Rein interessehalber)

Uwe Raabe 30. Nov 2019 15:37

AW: Verständnisfrage Assigned vs nil
 
Zitat:

Zitat von bcvs (Beitrag 1452511)
Wieso nicht? Ich hatte immer gedacht, das wäre auch da gleichwertig. (Rein interessehalber)

Probier's aus!

DeddyH 30. Nov 2019 16:52

AW: Verständnisfrage Assigned vs nil
 
Man könnte ja auch einfach mal die Doku bemühen.

hoika 30. Nov 2019 17:06

AW: Verständnisfrage Assigned vs nil
 
Hallo,
Tipp: Beim Zuweisungstest von Objektereignissen und -prozeduren können Sie nicht auf nil testen. Dazu müssen Sie Assigned verwenden.

Da steht es ;)

DeddyH 30. Nov 2019 19:13

AW: Verständnisfrage Assigned vs nil
 
Sag ich ja ;)

DasWolf 2. Dez 2019 09:38

AW: Verständnisfrage Assigned vs nil
 
Zitat:

Zitat von DieDolly (Beitrag 1452498)
Ich glaube wenn man mit
Delphi-Quellcode:
.Free
etwas freigibt, ist
Delphi-Quellcode:
Assigned()
False und
Delphi-Quellcode:
= nil
auch False.
Deswegen setze ich manuell immer alles auf nil wenn ich etwas mit Free freigebe.

Nagel mich nicht drauf fest. Bin mir unsicher.


Wenn etwas mit
Delphi-Quellcode:
.Free
freigegeben wird, dann ergibt die Abfrage mit
Delphi-Quellcode:
Assigned()
TRUE und die Abfrage auf
Delphi-Quellcode:
= nil
FALSE.

Wenn etwas mit
Delphi-Quellcode:
FreeAndNil()
freigegeben wird, dann ergibt die Abfrage mit
Delphi-Quellcode:
Assigned()
FALSE und die Abfrage auf
Delphi-Quellcode:
= nil
TRUE.

DieDolly 2. Dez 2019 11:13

AW: Verständnisfrage Assigned vs nil
 
Zitat:

Wenn etwas mit .Free freigegeben wird, dann ergibt die Abfrage mit Assigned() TRUE und die Abfrage auf = nil FALSE.
Also ist Assigned() und die Prüfung auf nil nicht gleichwertig wie vermutet WENN man nur mit .Free freigibt statt FreeAndNil.

himitsu 2. Dez 2019 11:20

AW: Verständnisfrage Assigned vs nil
 
Delphi-Quellcode:
procedure TCustomForm.Paint;
begin
  if TMethod(FOnPaint).Code <> nil then FOnPaint(Self);
end;
Wer will, der kann alles.
Methoden-Zeiger bestehen intern aus zwei Pointern (auf die Prozedur und auf das Object/Self).
Aber Assigned kennt die Unterschiede und nimmt dann die passende Prüfung vor.

Assigned und <>nil sind gleich, egal ob man mit Free oder FreeAndNil arbeitet.
Bei Free bleibt halt nur der nun "ungülige" Zeiger in der Variable drin, weswegen man das prüfen kann was man will.
Delphi-Quellcode:
obj.Free;
obj := nil;
FreeAndNil macht hier aber erst nil und dann Free (mit temporäter Variable dazwischen), damit wenn es im Free (Destroy) knallt, die Variable dennoch auf nil gesetzt wird/wurde.

Noch mehr Spaß macht es bei den generischen References (
Delphi-Quellcode:
reference to procedure
... die Zeiger wo Prozeduren und Methoden drin sein können),
denn da hast du ein "geheimes" Interface, wo dann der Zeiger drin ist.


@DasWolf
Versuch dir nicht zu merken wie es unterschiedlich ist, sondern merk es dir so, dass es gleich ist.

Delphi-Quellcode:
o <> nil
=
Delphi-Quellcode:
Assigned(o)

Delphi-Quellcode:
o = nil
=
Delphi-Quellcode:
not Assigned(o)

und nach
Delphi-Quellcode:
o.Free
ist eine Variable ungülig, also will man nachher auf nil/Assigned prüfen, dann muß auch auf NIL gesetzt werden (z.B. durch FreeAndNil).

DeddyH 2. Dez 2019 12:13

AW: Verständnisfrage Assigned vs nil
 
Nochmal aus der Doku:
Zitat:

Hinweis:Assigned kann keine hängenden Zeiger erkennen – d.h. Zeiger, die auf keine gültigen Daten mehr verweisen, aber dennoch nicht nil sind. In dem Codebeispiel für Assigned (SystemAssigned) wird von Assigned nicht erkannt, dass P nicht gültig ist.
Die entsprechende Variable enthält ja nach dem Freigeben weiterhin eine Speicheradresse, nur ist dort nicht mehr das drin, was vorher drin war. Erst durch Setzen von nil wird kenntlich gemacht, dass diese Adresse nicht mehr gilt.

Luckie 2. Dez 2019 13:49

AW: Verständnisfrage Assigned vs nil
 
Wenn ich ein Objekt nach der Freigabe im Code nachher auf Nil testen muss, dann habe ich was falsch gemacht. Wir hatten hier mal die Diskussion warum FreeAndNil schlechter Stil ist. Vielleicht findet die noch jemand. Da würde das sehr schlüssig erklärt von einem Mitglied.


Alle Zeitangaben in WEZ +1. Es ist jetzt 11:40 Uhr.
Seite 2 von 4     12 34      

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