exception vs. function return
Hallo :hi:,
ich suche ne saubere Lösung für folgende Situation: Ich hab ne Funktion, die Eingaben überprüft: CheckParams(). Diese löst, wenn sie n Eingabefehler gefunden hat(z.B. ungültige Mail-Adresse), ne Exception aus. In ner anderen Funktion wird CheckParams aufgerufen und ggf. weitergemacht oder abgebrochen. Realisierungsmöglichkeiten gibts da mehrere(der eigentliche Code is in PHP; die Sprache macht aber keinen Unterschied, also hier Delphi-Pseudo-Code): Möglichkeit1:
Delphi-Quellcode:
Möglichkeit2:
procedure TMyClass.CheckParams;
begin if not IsValid then raise Error; end; procedure TMyClass.DoSomething; begin CheckParams; DoWork; end;
Delphi-Quellcode:
Weitere Möglichkeiten:
function TMyClass.CheckParams: Boolean;
begin if IsValid then begin result := true; end else begin raise Error; result := false; end; end; function TMyClass.DoSomething: Boolean; begin if CheckParams then begin DoWork; result := true; end else begin result := false; end; end; Alle denkbaren Mischformen zwischen diesen beiden "Extremen". Die erste Möglichkeit hat den Vorteil, dass man wenig zu schreiben hat, dass die Eingaben überhaupt geprüft werden sieht man aber erst auf den zweiten Blick. Man muss sich erst CheckParams angucken, bevor man kapiert, dass wirklich vorher abgebrochen wird. Ein weiterer Nachteil ist, dass man von außen(das ganze befindet sich in ner Klasse) das selbe Problem hat. Ob DoSomething erfolgreich war, merkt man nur per Exception. Die zweite Möglichkeit behebt zwar die Probleme, dafür gibts aber wieder mehr Tipparbeit und vor allem Code, der nie ausgeführt wird, was auch wieder verwirrend ist. Wie also stellt man das am ungeschicktesten an? :gruebel: Was ist die sauberste Möglichkeit? mfg Christian |
Re: exception vs. function return
Exception sind Ausnahmen und sollten auch so verwendet werden. Also nur, wenn ein nicht behebbarer Fehler aufgetreten ist. Ich empfehle immer Rückgabewerte zu verwenden wenn es geht. Denn: Exceptions sind sehr langsam und produzieren einiges an Overhead.
Zudem wird es von den Aufrufer wieder mehr Tipp-Arbeit, da er dann den try ... except block anlegen muss. Denn sonst kommt es zu einer unschönen Message, die selten so gewünscht ist... P.S: Wozu brauchst denn dann noch bei Möglichkeit 2 eine Exception. Bei einer Exception wird die Verabeitung bis zurück zum letzen try ... except abgebrochen. |
Re: exception vs. function return
Zitat:
mfg Christian |
Re: exception vs. function return
Wie wärs denn mit einer Rückgabeklasse mit nem Feld IsValid und gegebenenfalls einem Feld ErrorString wie bei Exceptions?
|
Re: exception vs. function return
Zitat:
mfg Christian |
Alle Zeitangaben in WEZ +1. Es ist jetzt 19:03 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