AW: Absturz der Anwendung nach beenden eines Threads
Zitat:
Grundsätzlich gehe ich aber mal davon aus, dass eher ich einen Fehler mache als Francois Piette :) |
AW: Absturz der Anwendung nach beenden eines Threads
Läßt sich das Problem anhand eines minimalen Beispielprojekts reproduzieren (das man dann hier posten könnte)?
madExcept würde ich bei Abstürzen auch als allererstes benutzen um den Callstack zu erhalten. (es ist fast schon ein must-have Werkzeug). |
AW: Absturz der Anwendung nach beenden eines Threads
Also ich habe mir jetzt im Thread im OnTerminate per PostMessage eine Message an den Hauptthread schicken lassen.
Dann rufe ich folgende Procedure auf
Delphi-Quellcode:
Erzeugen tu ich es so:
Writelog('Message TCPComThreadEnded empfangen');
for I := ComThreadList.Count-1 downto 0 do begin if TTCPThread(ComThreadList[i]).Finished then begin Writelog('FreeAnNil TCPComThread'); TTCPThread(ComThreadList[i]).Free; Writelog('Thread aus TObjectList entfernen'); ComThreadList.Delete(i); //<- Hier tritt eine Exception auf, dass das Object nicht mehr da ist. end; end;
Delphi-Quellcode:
Muß ich es auf der ComThreadList nicht mehr löschen?
TCPThread:=TTCPThread.Create(False, '192.168.177.71', localport, ip, port, self.Handle);
ComThreadList.Add(TCPThread); Wenn ich bei ComThreadList.Delete(i) eine Haltepunkt setze, und alle im Einzelschritt durchgehe, dann lande ich in der Unit "System.Classes" in der Funktion "TThread.destroy". Das kommt aber wahrscheinlich durch den Aufruf von .Free (2 Zeilen drüber). Und ich lande hier:
Delphi-Quellcode:
destructor TThread.Destroy;
begin if (FThreadID <> 0) and not FFinished and not FExternalThread then begin Terminate; if FCreateSuspended or FSuspended then Resume; WaitFor; end; RemoveQueuedEvents(Self); {$IF Defined(MSWINDOWS)} if (FHandle <> 0) and not FExternalThread then CloseHandle(FHandle); //<- Hier habe ich eine Exception: // Im Project WSPRG.exe ist eine Exception der Klasse $C00000005 mit der // Meldung 'Zugriffsverletzung bei 0x00000000: Lesen von Adresse 0x00000000' aufgetreten {$ELSEIF Defined(POSIX)} // This final check is to ensure that even if the thread was never waited on // its resources will be freed. if (FThreadID <> 0) and not FExternalThread then pthread_detach(pthread_t(FThreadID)); {$IF Defined(MACOS)} pthread_mutex_destroy(FCreateSuspendedMutex); {$ELSEIF Defined(LINUX)} sem_destroy(FCreateSuspendedSem); {$ENDIF LINUX} {$ENDIF POSIX} inherited Destroy; FFatalException.Free; end; |
AW: Absturz der Anwendung nach beenden eines Threads
Zitat:
|
AW: Absturz der Anwendung nach beenden eines Threads
Okay, das funktioniert :-) Danke Uwe.
Allerdings besteht mein ursprüngliches Problem immer noch. Jetzt habe ich mir mal das MADExcept heruntergeladen und auch in den madexcept Settings aktiviert. Meine Exe wird auch größer, und jetzt sollte doch eigentlich bei einer Exception ein Fenster mit Debuginfo's kommen. Allerdings bekomme ich nach wie vor entweder die Fehlermeldung von Windows, oder er geht ins Debugging der IDE. Muß man noch was anderes machen, damit madexcept die Exception abfängt? |
AW: Absturz der Anwendung nach beenden eines Threads
Entweder du sagst der Objektliste die soll das löschen (OwnsObjects) und selber löschst du das nicht mehr,
wobei hier das Delete die TThread-Instance löscht. Aber wenn du das unbedingt selber löschen willst, dann darf entwedet die Liste das nicht automatisch löschen (kein OwnsObjects) oder du mußt den "ungültigen" Zeiger via TObjectList.Extract rausholen. |
AW: Absturz der Anwendung nach beenden eines Threads
Ich habe jetzt OwnObjects:=False und lösche das Object jetzt selber. Das Free hab ich rausgenommen und so funktioniert es jetzt auch.
Aber mein Ursprüngliches Problem ist noch da und das mit dem madexcept will auch nicht funktionieren (Wär ich heut bloß im Bett geblieben) |
AW: Absturz der Anwendung nach beenden eines Threads
Zitat:
Wenn Windows die Exception fängt, dann müsste man das mal genauer untersuchen, wo die Exception hochkommt. Hast du alle Checks (Range checking, Overflow checking) aktiviert? |
AW: Absturz der Anwendung nach beenden eines Threads
Liste der Anhänge anzeigen (Anzahl: 1)
Okay, das mit den madexcept läuft jetzt. Ich habe eine bugreport, aus dem ich selbst leider nicht so viel herauslesen kann. Ich häng den mal an Anhang dran, vielleicht kann jemand etwas daraus erkennen.
Wenn ich dann in der madException auf Continue Application klicke, läuft meine Anwendung scheinbar weiter, bis ich der Mainform mal wieder den Focux spendiere. |
AW: Absturz der Anwendung nach beenden eines Threads
Zitat:
Es gibt also nur noch das Delete in der Liste. Nja, dann hast du den Thread-Zeiger nun aus der Liste, aber die Thread-Instanz gammelt als Speicherleck immernoch im Programm rum. Einwas davon mußt du schon noch machen (nur Eines und nicht Mehreres). |
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:33 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