Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Exceptions und so ... Gedankenspiele (https://www.delphipraxis.net/190326-exceptions-und-so-gedankenspiele.html)

bernau 23. Sep 2016 09:00

Delphi-Version: 10 Seattle

Exceptions und so ... Gedankenspiele
 
Der Vortrag von Bernd Ua, bei den letzten Delphi-Tagen, hat mich veranlasst etwas mehr über Exception-Behandlung nachzudenken. (Danke übrigens für den tollen Vortrag)

Exceptions haben im Laufe der Zeit bei mir eine Evolution erlebt.

Früher Exceptions tot geschwiegen.

Delphi-Quellcode:
try
  // hier der Code mit Fehlern
except
  // Hier überhaupt nichts drin
end;
  // Und blos kein Finally (würg)
Heute rege Benutzung von Exceptions.

Aber es gibt ja immer noch was zu lernen und zum Nachdenken. Dank dem Vortrag von Bernd.

***************************************

Genug der Worte. Hier mal eine Frage.

Oft wiederholen sich Exceptions und die dazu vorherige Auswertung.

Delphi-Quellcode:
if not inrange(aIndex,MinValue,MaxValue) then
  Raise Exception.create('Index out of range: Index='+inttostr(aIndex)+' MinValue='+inttostr(MinValue)+' MaxValue='+inttostr(MaxValue));
Spricht irgendwas dagegen dies in einer Funktion zusammen zu fassen?

Delphi-Quellcode:
Procedure RaiseIfNotInRange(aIndex:Integer;aMinValue:Integer;aMaxValue:Integer);
begin
if not inrange(aIndex,aMinValue,aMaxValue) then
  Raise EMyOutOfRangeException.create('Index out of range: Index='+inttostr(aIndex)+' MinValue='+inttostr(aMinValue)+' MaxValue='+inttostr(aMaxValue));
end;
Dann im Code nur noch folgendes aufrufen.

Delphi-Quellcode:
  RaiseIfNotInRange(aIndex,3,10);


Ist doch viel weniger Tipparbeit. Spricht etwas dagegen das so zu machen? Leidet die Lesbarkeit? Ich weis, ist ne banale Frage. Einfach machen und gut ist. Aber die Meinungen dazu interessieren mich schon.

Der schöne Günther 23. Sep 2016 09:12

AW: Exceptions uns so ... Gedankenspiele
 
So ein Konstrukt findest du in der RTL ziemlich oft, und nicht nur dort. Meistens aber nicht mit "RaiseIfXYZ(..)" sondern "CheckXYZ(..)".
Vor allem wenn du, beispielsweise eine Zahl, nicht nur auf Grenzbereiche prüfen willst, sondern noch andere Dinge zum Tragen kommen. Beispielsweise nur grade Zahlen oder was auch immer.


Das geht schon leicht an der eigentlichen Frage vorbei, aber wenn du wirklich glaubst deine eigene
Delphi-Quellcode:
EMyOutOfRangeException
zu erfinden und nicht die bereits bestehende
Delphi-Quellcode:
EArgumentOutOfRangeException
(die sich von
Delphi-Quellcode:
EArgumentException
ableitet), dokumentier das bitte! Als Benutzer möchte ich immer sehen welche Exceptions ich zu erwarten habe.

PS: Ich war leider nicht bei seinem Vortrag, höre aber immer nur Lobpreisungen über Herrn Ua. Kann mir einer eine kurze Zusammenfassung geben was gepredigt wurde?

JasonDX 23. Sep 2016 09:22

AW: Exceptions und so ... Gedankenspiele
 
Ich finde hier die Idee der Preconditions aus Guava recht praktisch. Diese orientieren sich aber primär an den Exceptions, die sie werfen (InvalidArgumentException, NullPointerException, IllegalStateException, etc.). Der Kontext der Prüfung kann dann in die Message der Exception verpackt werden.

Etwas Delphi-ähnliches ließe sich auch recht leicht realisieren, wobei ich mich hier (Wie Günther schon sagt) meist an generelleren Exceptions orientieren würde - vereinfacht auch die Wiederverwendung in anderen Projekten.

Stevie 23. Sep 2016 09:26

AW: Exceptions und so ... Gedankenspiele
 
Der Vorteil des raisen von Exceptions in einer entsprechenden Routine (außer, dass man seinen Code wiederverwertbar kapselt) und nicht direkt im Code, der sie verursacht wurde von Eric Grange schonmal schön erklärt.

Zitat:

Zitat von JasonDX (Beitrag 1348612)
Ich finde hier die Idee der Preconditions aus Guava recht praktisch. Diese orientieren sich aber primär an den Exceptions, die sie werfen (InvalidArgumentException, NullPointerException, IllegalStateException, etc.). Der Kontext der Prüfung kann dann in die Message der Exception verpackt werden.

Etwas Delphi-ähnliches ließe sich auch recht leicht realisieren, wobei ich mich hier (Wie Günther schon sagt) meist an generelleren Exceptions orientieren würde - vereinfacht auch die Wiederverwendung in anderen Projekten.

Gibt's schon in ähnlicher Form, nennt sich
Delphi-Quellcode:
Spring.Guard
.

Obiger Code sähe damit so aus:

Delphi-Quellcode:
Guard.CheckRangeInclusive(aIndex, MinValue, MinValue);


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:04 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