AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Try..except außerhalb des VCL-Threads
Thema durchsuchen
Ansicht
Themen-Optionen

Try..except außerhalb des VCL-Threads

Ein Thema von Delphi-Laie · begonnen am 25. Aug 2012 · letzter Beitrag vom 27. Aug 2012
Antwort Antwort
Seite 1 von 2  1 2      
Delphi-Laie

Registriert seit: 25. Nov 2005
1.474 Beiträge
 
Delphi 10.1 Berlin Starter
 
#1

Try..except außerhalb des VCL-Threads

  Alt 25. Aug 2012, 16:21
Hallo Delphifreunde!

Ich beziehe mich auf jene Diskussion, in der mir gut geholfen wurde (danke nochmal dafür!).

Nunmehr lagere ich die zeitintensiven Berechnungen sukkzessiv in externe Threads aus, es klappt soweit auch ganz gut. Der Zugriff auf einige VCL-Elemente bzw. -Funktionen ist teilweise erschwert, es muß dann mit synchronize gearbeitet werden, aber die Vorteile am fertigen Programm sind naütrlich erheblich.

Doch jetzt wird es schwieriger. Eine bestimmte Berechnung erlaubt nicht alle Eingaben (das ist ja in der Mathematik sehr oft so), und derart ungültige Berechnungen werden mit try abgefangen (wohl der einfachste Weg, anstatt die Eingabewerte "mühsam" und ggf. sogar einzeln auf Konsistenz zu prüfen):

Delphi-Quellcode:
try
//Versuch der Berechnung
except showmessage('Fehler')
end;
funktionierte im VCL-Thread tadellos, sodaß das Programm auch bei ungültigen Eingaben eine Fehlermeldung ausgibt und danach problemlos weiterläuft, anstatt abzustürzen.

Im Extra-Rechenthread jedoch funktioniert das

Delphi-Quellcode:
procedure Fehlermeldung;
begin
showmessage('Fehler')
end;

.
.
try
//Versuch der Berechnung
except synchronizie(Fehlermeldung)
end;

nur insoweit, als daß die Fehlermeldung zwar auch kommt, wenn die Bedingungen dafür gegeben sind, jedoch danach das Programm dennoch mit einer Fehlermeldung ("Exception") abstürzt.

Kann man dem try-except-block die volle Funktionalität wie im VCL-Thread verpassen, also diesen Absturz irgendwie vermeiden?

Danke im voraus und Gruß

Delphi-Laie
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.442 Beiträge
 
Delphi 12 Athens
 
#2

AW: Try..except außerhalb des VCL-Threads

  Alt 25. Aug 2012, 16:41
nur insoweit, als daß die Fehlermeldung zwar auch kommt, wenn die Bedingungen dafür gegeben sind, jedoch danach das Programm dennoch mit einer Fehlermeldung ("Exception") abstürzt.
Welche Exception kommt denn genau?
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Delphi-Laie

Registriert seit: 25. Nov 2005
1.474 Beiträge
 
Delphi 10.1 Berlin Starter
 
#3

AW: Try..except außerhalb des VCL-Threads

  Alt 25. Aug 2012, 16:50
nur insoweit, als daß die Fehlermeldung zwar auch kommt, wenn die Bedingungen dafür gegeben sind, jedoch danach das Programm dennoch mit einer Fehlermeldung ("Exception") abstürzt.
Welche Exception kommt denn genau?
Siehe Anhang.

Sie kommt nach meiner selbstprogrammierten Fehlermeldung, und danach ist mit dem Programm Ende.

Wie gesagt, als alles im VCL-Thread lief, lief es wie gewünscht.
Miniaturansicht angehängter Grafiken
fehlermeldung.jpg  
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.442 Beiträge
 
Delphi 12 Athens
 
#4

AW: Try..except außerhalb des VCL-Threads

  Alt 25. Aug 2012, 17:55
Die Excepion hat eine andere Ursache. Überprüfe mal, ob die im Fehlerfall nicht doch irgendwelche Variablen verwendest, die dann noch nicht oder nicht mehr da sind. Immerhin wird der Code im Thread nicht vollständig durchlaufen, sondern mittendrin durch die Exception abgebrochen.

Wenn du mehr wissen willst, musst du mehr Code liefern.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Delphi-Laie

Registriert seit: 25. Nov 2005
1.474 Beiträge
 
Delphi 10.1 Berlin Starter
 
#5

AW: Try..except außerhalb des VCL-Threads

  Alt 25. Aug 2012, 18:34
Die Excepion hat eine andere Ursache.
Eine andere Ursache als was?

Überprüfe mal, ob die im Fehlerfall nicht doch irgendwelche Variablen verwendest, die dann noch nicht oder nicht mehr da sind.
Mit Sicherheit kann etwas nicht (richtig) konvertiert werden, das war mir gleich klar, aber dafür ist try..except schließlich da und funktionerte doch vorher auch.

Immerhin wird der Code im Thread nicht vollständig durchlaufen, sondern mittendrin durch die Exception abgebrochen.
Ja, aber genau dafür, um so etwas abzufangen, ist schließlich doch try..except da (jetzt wiederhole ich mich allmählich)?! Wie kann ein und derselbe Code in einem Thread eine exception auslösen, im anderen Code, der im VCL-Thread läuft, die exception abgefangen werden? Leuchtet mir nicht ein.

Wenn du mehr wissen willst, musst du mehr Code liefern.
Das ist leider nicht so einfach, denn es spielen mehrere Routinen und Deklarationen aus mehreren Units mit. Aber wenigstens scheint sich auch Nicht-VCL-Thread-Code im Quelltext via Debugger schrittweise nachverfolgen zu lassen.

Danke an Dich erstmal für Dein Bemühen!

Geändert von Delphi-Laie (25. Aug 2012 um 18:37 Uhr)
  Mit Zitat antworten Zitat
Delphi-Laie

Registriert seit: 25. Nov 2005
1.474 Beiträge
 
Delphi 10.1 Berlin Starter
 
#6

AW: Try..except außerhalb des VCL-Threads

  Alt 25. Aug 2012, 18:57
So, ich bin ein Stück weiter.

Schuld ist nicht irgendeine der externe Berechnungsfunktionen aus einer externen Unit, sondern - als Argument dafür - eine schnöde Typkonvertierung (prinzipieller Quellcode):

Delphi-Quellcode:
try
strtoint([String(variable)])
except
, wobei der String, als Integerzahl gedacht, größer als der größtmögliche Wert der Integervariablen ist (der String könnte genausogut ungültige Zeichen enthalten, gerade ausprobiert).

Außerhalb des VCL-Threads funktioniert try..except offenbar nur eingeschränkt: Except wird zwar aufgerufen, die Exception jedoch nicht abgefangen.

Geändert von Delphi-Laie (25. Aug 2012 um 19:00 Uhr)
  Mit Zitat antworten Zitat
Delphi-Laie

Registriert seit: 25. Nov 2005
1.474 Beiträge
 
Delphi 10.1 Berlin Starter
 
#7

AW: Try..except außerhalb des VCL-Threads

  Alt 25. Aug 2012, 19:30
Fehler gefunden: Es lag am Aufruf einer anderen Prozedur, die immer, also auch nach dem try..except, aufgerufen wurde. (Ermitteln der Systemzeit, jedenfalls ist der zentrale Befehl in jener Prozedur QueryPerformanceCounter. Das passiert, um die Rechendauer zu ermitteln.)

Mit dem nur noch optionalem Aufruf der Prozedur (nicht, wenn except aufgerufen wird, dann wird eine boolesche Variable auf false gesetzt, was den späteren Aufruf verhindert) ist der Programmabbruch vermeidbar.

Dieses Programmverhalten leuchtet mir nicht ein und stellte im VCL-Thread auch kein Problem dar.

Danke noch einmal, Uwe!

Ergänzung: Ganz so sauber, wie dargestellt, lief es auch im VCL-Thread doch nicht ab: Nach der programmierten Fehlermeldung kam auch noch eine exception hinterher, aber das Programm stürzte nicht ab (indem es aus dem Speicher verschwand), sondern ließ sich nach dem "Wegklicken" letzter weiterbenutzen.

Geändert von Delphi-Laie (25. Aug 2012 um 19:42 Uhr)
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#8

AW: Try..except außerhalb des VCL-Threads

  Alt 27. Aug 2012, 00:22
Dann verhält sich aber nicht try..except anders, sondern der Fehler in deinem Code hat in einem anderen Thread schwerwiegendere Auswirkungen. Er sollte jedenfalls in beiden gefixed werden

Ich bin auch kein großer Fan von ShowMessage in Threads. Ich mir angewöhnt um die Execute-Methode immer komplett(!) noch einen try..except zu bauen, in dessen execpt-Teil in ein Logfile oder eine Tabelle protokolliert wird. Zusätzlich zu den in dieser aufgerufenen Methoden, die ggf. selbst auch loggen um Fehler genauer eingrenzen zu können. Gerade wenn mehrere Threads rege miteinander interagieren vermeidet man so ggf. falsche Folgefehler, die dadurch kommen, dass andere Threads auf den dann angehaltenen warten während er synced die Meldung anzeigt.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#9

AW: Try..except außerhalb des VCL-Threads

  Alt 27. Aug 2012, 10:23
In einem Thread ShowMessage aufzurufen ist auch nicht so clever, da es ein VCL Dialog ist und damit nicht threadsafe. Nimm für so etwas mal die eine Messagebox von Windows. aber ich würde so wie so, die Exceptions im Thread nur auslösen und im Main Thread behandeln. Dann ist der Code auch besser wieder verwendbar.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#10

AW: Try..except außerhalb des VCL-Threads

  Alt 27. Aug 2012, 11:42
Wie würde man das machen Luckie? Ich kann ja um einen Thread im VCL-Thread kein try..except machen, da sie ja nicht parallel laufen. Ich behelfe mir hier oft auch mit eigenen Messages, die ich meinem Mainform poste, wenn ich nicht (wie oben beschrieben) loggen will / kann. Denen klebe ich dann meist einen Pointer zu einem Record an, der ggf. weitere Infos zum Fehler enthält (z.B. den Fehlertext), was durch das Gecaste und New() im Thread aber Dispose() im Mainthread immer etwas "unsafe" und gefummelt wirkt.

Alternativ ließe sich ja auch ein Error-Eventhandler in der Threadklasse synchronized aufrufen, was etwas hübscher ins OO-Konzept passt. Aber hier ist man dann auch wieder darauf angewiesen, dass der Handler im Mainthread nicht ggf. zu eben solch einer Blockade führt wie oben beschrieben.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:52 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