![]() |
TTask.Run(...) in DLLs
Mir ist gerade aufgefallen, dass die Verwendung von TTask.Run ein Problem mit der Speicherfreigabe hat, wenn man das in einer DLL verwendet.
Zitat:
Beim Entladen der Dll sollte dann DLLShutdown aufgerufen werden. Aber DLLShutdown wird anscheinend gar nicht aufgerufen. In der Unit hat diese Teil keine blauen Pünktchen. Kann es sein, dass das vergessen wurde? Mit XE7 gibt es übrigens kein Speicherproblem. |
AW: TTask.Run(...) in DLLs
Hi,
Zitat:
|
AW: TTask.Run(...) in DLLs
@WiPhi
Ja, das habe ich mal getestet indem ich DLLShutdown im finalization hinzugefügt habe. Das wurde dann auch ausgeführt, hat aber das Speicherleck nicht beseitigt. Das Freigeben erfolgt im ShutdownThreadPool in der System.Threading auch im class destructor TThreadPool.Destroy. Damit ist das RegisterDLLShutdown im initialization eigentlich überflüssig. Ich benötigte das TTask.Run nur gelegentlich zum Test um Tastaureingaben per TSendInputHelper zu senden und werde das nicht weiter untersuchen. |
AW: TTask.Run(...) in DLLs
Kann es sein, dass die Überprüfung einfach nur vor dem Ausführen des Codes erfolgt?
|
AW: TTask.Run(...) in DLLs
Zitat:
|
AW: TTask.Run(...) in DLLs
Ich habe mir nun doch die Mühe gemacht und den Ablauf mal genauer debugt.
Ich habe mal Haltepunkte in
Ohne TTask.Run wird Create und Destroy wird jeweils einmal aufgerufen. Beim 1. TTask.Run wird TLightweightEvent.Create 3 mal und destructor TLightweightEvent.Destroy nur einmal aufgerufen. Beim 2. TTask.Run TLightweightEvent.Create einmal und destructor TLightweightEvent.Destroy einmal Die Ursache habe ich inzwischen auch gefunden. Im destructor TThreadPool.Destroy ist IsDLLDetaching = True und in diesem Zweig wurde die Freigabe der Items vom FThreads.LockList vergessen. Wer 11.3 und die Quellen hat kann das in System.Threading.pas Zeile 2986 bis 2998 erkennen. Im else Zweig wird eine lokale Liste LocalFreeList aufgebaut und diese zu Freigeben verwendet (Zeile 3014 bin 3034). Die Feigabe erfolgt in Zeile 3027 bis 3028. Man sollte das als Bugreport anlegen, aber dazu ist mein Englisch etwas mau. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:02 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