AW: FreeAndNil macht Probleme
Zitat:
aber das hat nichts mit dem Überschreiben zu tun. Soll was beim Freigeben gemacht werden, dann kommt es ins Destroy rein, mit Override. Extern benutzt du Free (weil dort das If-Assigned eingeaut ist), aber intern kommt der Code ins Destroy. Ein paar Beispiele, warum "überdecken" statt Überschreiben selten eine gute Idee ist. Bei TStrings und TStream verwentet man meistens die Basisklasse für Varisblen und Parameter, damit man die Funktion unabhängig von der Quelle implementieren kann, aber beim Erstellen wird dann dir Endklasse benutzt. Sind da Methoden nur verdeckt, dann werden sie nie verwendet, siehe dein Free. |
AW: FreeAndNil macht Probleme
Ich hatte gerade vor kurzer Zeit etwas über Verdecken und Überschreiben gelesen, und es war mir nicht so richtig klar geworden, warum Verdecken jetzt soooo schlimm ist. Die Praxis ist halt der beste Lehrmeister. Insbesondere die Tatsache, dass ich diese Problematik nie an dieser Stelle vermutet hätte. Dabei kannte ich den Emba-Code und hatte bei SO gelesen, warum man den Umweg über eine Tempvariable gegangen ist.
|
AW: FreeAndNil macht Probleme
Ja, die TempVariable ist nur, weil FreeAndNil eben "erst Nil und dann Free" macht. :stupid:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:57 Uhr. |
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