Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   exception vs. function return (https://www.delphipraxis.net/69383-exception-vs-function-return.html)

r2c2 14. Mai 2006 17:36


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:
procedure TMyClass.CheckParams;
begin
  if not IsValid then
    raise Error;
end;

procedure TMyClass.DoSomething;
begin
  CheckParams;
  DoWork;
end;
Möglichkeit2:
Delphi-Quellcode:
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;
Weitere Möglichkeiten:
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

jim_raynor 14. Mai 2006 17:39

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.

r2c2 14. Mai 2006 17:51

Re: exception vs. function return
 
Zitat:

Zitat von jim_raynor
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.

Exceptions haben den Vorteil, dass man damit Fehlermeldungen übergeben kann. In meinem Fall hab ich nämlich ne PHP-Mail-Klasse. CheckParams löst dann ne Exception mit der entsprechenden Meldung aus. z.B. "Kein Empfänger angegeben", "Absender-Adresse üngültig" oder sowas. Die kann dann ausgegeben werden und der User weiß, was er falsch gemacht hat. Würde ich komplett auf Exceptions verzichten(Möglichkeit 3), dann müsste ich entweder n FehlerCode zurückliefern(nicht besonders aussagekräftig und mit unschönen Fallunterscheidungen und dem entsprechendne Overhead verbunden) oder in PHP die nicht vorhandene Typsicherheit missbrauchen und entweder n string als Fehlermeldung oder true zurückliefern, was ich als Delphi-verwöhnter Hobby-Progger extrem unschön fände...

mfg

Christian

Dax 14. Mai 2006 18:08

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?

r2c2 15. Mai 2006 17:26

Re: exception vs. function return
 
Zitat:

Zitat von Dax
Wie wärs denn mit einer Rückgabeklasse mit nem Feld IsValid und gegebenenfalls einem Feld ErrorString wie bei Exceptions?

Ui... Klasse Idee. :thumb: Funktioniert prima und is auch noch einfach zu implementieren... Danke!

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