@Alzaimar:
Zitat:
Delphi-Quellcode:
try
...
Except
On E:EThisException
Do Begin
HandleThisException(E);
End;
On E:EThatException
Do Begin
HandleThatException (E);
End;
On E:
Exception Do Begin
HandleAnyOtherException (E);
End;
End;
Ohne jetzt über Stilfragen diskutieren zu wollen, aber wir können das mal vergleichen:
Delphi-Quellcode:
try
except
on E:
Exception do
if E
is EThisException
then HandleThisException(E)
else
if E
is EThatException
then HandleThatException(E)
else HandleAnyException(E);
end;
1.) Lesbarkeit, bzw. Explizität dessen was man schreibt, nichts ist zuviel oder zu wenig umschrieben.
2.) ob man on E: XYZ do abfragt oder E is XYZ ist egal, dahinter wird der Compiler den gleichen Code erzeugen, für die Klassentyp Abfrage.
3.) Programablaufpfad, bei deiner Lösung fragst du unnötigerweise mit wesentlich höherer Wahrscheinlichkeit die
Exception Klasse ab. Bei meinem wird auf grund der kaskadierten IF Abfrage die Wahrscheinlichkeit das zb. HandleAnyException() aufgerufen wird drastisch reduziert das die Wahscheinlichkeiten für EThisException und ETahtException davon abzuziehen sind.
Mein Vorschlag ist also effizenzter.
Gruß Hagen