![]() |
AW: Objekte einer TObjectList direkt aus dem Speicher lesen / in ihn schreiben
Darf ich fragen, warum in Sir Rufos Beispiel das
Delphi-Quellcode:
nötig ist? Der Compiler beanstandet, die Variablen würden nie benutzt.
Stream := nil;
VSBStream := nil; |
AW: Objekte einer TObjectList direkt aus dem Speicher lesen / in ihn schreiben
Zitat:
![]() Am Ende ist Exception-sicheres Programmieren aber immer anstrengend. Nicht wegen den Exceptions, sondern weil das Problem (fehlertolerantes Programmieren) halt schwer ist. |
AW: Objekte einer TObjectList direkt aus dem Speicher lesen / in ihn schreiben
Zitat:
Delphi-Quellcode:
Bei Interfaces biete es sich an die Exceptionbehandlung in einem Decorator(Entwurfsmuster) zu implementieren.
type
TMyObject = class(TObject) protected procedure TuWas; procedure TuWasMitObject(AObject: TObject); procedure TuWasAnderes; public procedure TuIrgendWas; end; implementation procedure TMyObject.TuWas; var lObject: TObject; begin lObject := TObject.Create; try TuWasMitObject(lObject); finally lObject.Free; end; end; procedure TMyObject.TuWasAnderes; begin {...} end; procedure TMyObject.TuIrgendWas; begin try TuWas; except TuWasAnderes; end; end; |
AW: Objekte einer TObjectList direkt aus dem Speicher lesen / in ihn schreiben
Zitat:
Insofern gibt es aber genügend moderne Hilfsmittel, die die eigentliche Kärrnerarbeit schon erledigen. Man muss sie nur nutzen. |
AW: Objekte einer TObjectList direkt aus dem Speicher lesen / in ihn schreiben
Zitat:
![]() |
AW: Objekte einer TObjectList direkt aus dem Speicher lesen / in ihn schreiben
@DeddyH
Verstehe. Ich liege aber doch wohl richtig mit der Annahme, dass es so zwar nicht bei der Freigabe rumst, aber dennoch der Anwender bei einem einfachen Finally mit einer Meldung konfrontiert wird, was man ja nicht will. Ich glaube, ich werde es prinzipiell eher mit dem Vorgehen von Uwe Raabe halten (vorausgesetzt, ich habe ihn richtig verstanden), bzw. Weg 1 wählen. Es kommt halt nur öfter vor, dass ich einen bestimmten Codeteil in jedem Fall ausführen will und Sprungmarken (von der generellen Kritik abgesehen) nicht hilfreich sind, weil sie nicht aus dem Block herausführen dürfen. (Ich bin da, glaube ich, etwas von dem praktischen "On Error GoTo" von VBA beeinflusst.) Die neu gewonnene Erkenntnis, dass Finally auch bei einem vorhergehenden Exit ausgeführt wird, ist vielleicht peinlich, aber sehr hilfreich. Übrigens funktioniert die ganze Chose mittlerweile recht gut, jedenfalls zu meiner Zufriedenheit. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:49 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 by Thomas Breitkreuz