![]() |
try.......except....end; - Compiler soll dies beachten
Hallo,
gibt es eine möglichkeit, das Delphi, try except, beim ausführen mit dem debugger beachtet? Lg Simon |
AW: try.......except....end; - Compiler soll dies beachten
Ich verstehe die Frage nicht, kannst Du etwas konkreter werden?
|
AW: try.......except....end; - Compiler soll dies beachten
Code:
Wenn beim Debuggen ein Fehler bei "x:=1" auftritt, dann bleibt der debugger stehen und führt nicht automatisch den except teil stattdesen aus.
try
x := 1 except x := 2 Ich würde es gerne haben das delphi beim debuggen automatisch den except teil hernimmt, wenn der try teil einen fehler hat. |
AW: try.......except....end; - Compiler soll dies beachten
Dann musst Du dem Debugger sagen, er soll diese(n) Exception(typ) ignorieren.
|
AW: try.......except....end; - Compiler soll dies beachten
Zitat:
Wenn du das nicht möchtest, kannst du wie mkinzler schon geschrieben hat den Exceptiontyp ignorieren. In einigermaßen aktuellen Delphiversionen geht das direkt in dem Dialog, den der Debugger anzeigt, in alten Versionen nur über die Optionen. |
AW: try.......except....end; - Compiler soll dies beachten
Wird diese Exception denn oft ausgelöst?
Grundsätzlich wäre es besser, wenn man erstmal vermeidet, daß eine Exception überhaupt ausgelöst wird ... dann braucht man dem Debugger auch keine Ausnahme beibringen. :stupid:
Delphi-Quellcode:
try
i := StrToInt('abc'); except i := 0; end; |
AW: try.......except....end; - Compiler soll dies beachten
Zitat:
Vielleicht so: Grundsätzlich wäre es besser, wenn der happy path programmiert wird, d.h. man geht z.B. davon aus, das der String eine Zahl ist (wenn man davon ausgehen kann), die Verbindung zustande kommt, der Divisor <> 0 ist (wenn das kein Sonderfall, d.h. Bestandteil der Formel ist) usw. Als Prüfung, ob der String eine Zahl ist, eignet sich das try-except-pattern nicht, da hast Du vollkommen recht.
Delphi-Quellcode:
// Happy Path
try DoThis; DoThat; C := A/B; Number:= StrToInt(aString); except ShowMessage('This did not work properly'); end; // Prüfung if TryStrToInt(aString, Number) then Number := StrToInt(aString); else ShowMessage('Cannot convert'); // Oder mach sonst irgendwas if Not IsZero(B) then C:=A/B else c:= NaN; if CanConnectTo(URL) then ConnectTo(URL) else ShowMessage('Cannot connect to '+URL); |
AW: try.......except....end; - Compiler soll dies beachten
OT-Korinthenmodus
Zitat:
@happy path (grundsätzlich) Besonders happy wäre ich oder der Anwender vielleicht mit der Original Fehlernummer/-Meldung und einer Ausgabe der Variableninhalte, die zum Fehler geführt haben. /OT-Korinthenmodus |
AW: try.......except....end; - Compiler soll dies beachten
Ich greife das Thema nochmal auf, weil ich ein ähnliches Problem habe, mit einer Exception, die aus Indy kommt, wenn keine Verbindung aufgebaut werden kann.
Naütrlich kann ich im Debugger sagen, dass er diese Exception ignorieren soll. Allerdings gilt es dann zum einen für alle Exceptions, wo keine Verbindung aufgebaut werden kann, zum anderen muss ich das immer auf allen Delphi Installationen neu machen. Gibt es nicht einfach eine Compilerdirektive, wo man sagen kann "diese Exception nie an den Debugger melden"? Gerade in Threads führt diese Exception bei mir nämlich oft dazu, dass die ganze IDE hängt, wenn ich F9 drücke. |
AW: try.......except....end; - Compiler soll dies beachten
Nein, leider nicht. Das nervt mich auch ständig.
|
AW: try.......except....end; - Compiler soll dies beachten
Den Wunsch, programmseitig Exceptions regel zu können, hat Embarcadero NICHT vor etwas bieten zu wollen.
Ich war auch noch nicht dazu gekommen, etwas Derartiges zu bereitzustellen, (nur die Umsetzungsidee liegt irgendwo in 'ner Schublade und wartet) vor allem, da es hier noch weitere Wünsche bezüglich des Exceptionhandlings der IDE gibt. |
AW: try.......except....end; - Compiler soll dies beachten
Es gibt noch den Exception-Filter Expert in GExperts. Allerdings weiß ich nicht, wie gut der im aktuellen Delphi funktioniert, da ich ihn nur für Delphi 2007 und 10.2 häufiger verwende. Die Implementation ist ein ziemlicher Hack und jedes IDE-Update kann dazu führen, dass es nicht mehr funktioniert.
|
AW: try.......except....end; - Compiler soll dies beachten
Hallo,
so sehr ich den Frust verstehen kann, so denke ich kann der Debugger halt nicht wissen, woher die Exception kommt, zumindest nicht so mit einem $IFDEF oder so. Der Debugger müsste sich wohl den Absprungpunkt und die Exception Klasse merken für jede so zu behandelnde Exception merken. |
AW: try.......except....end; - Compiler soll dies beachten
Das Problem ist an der Stelle (wahrscheinlich) eher Indy, das fröhlich mit Exceptions auch an Stellen wirft, an denen die nicht unbedingt nötig sind. Klassiker ist z.B. bei http, wenn noch eine Antwort gesendet werden soll, aber die andere Seite nicht mehr "zuhört". Ich finde die Stelle auf die Schnelle gerade nicht, aber wenn ich mich recht entsinne, dann steht in dem Quellcode sogar sowas wie "die Exception hier kann man eigentlich meistens ignorieren" - und ich denke mir immer: "ja, warum werft ihr sie dann?!".
An der Stelle wäre es also eigentlich aus meiner Sicht wünschenswerter, wenn man den Umgang von Indy mit Exceptions etwas ändern könnte, anstatt das Problem über die IDE zu lösen. |
AW: try.......except....end; - Compiler soll dies beachten
Zitat:
Zitat:
Zitat:
Ich habe Exceptions auch schon so genutzt. Das hat Vor- und Nachteile. |
AW: try.......except....end; - Compiler soll dies beachten
Zitat:
Zitat:
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:04 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-2025 by Thomas Breitkreuz