Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Delphi Delphi 2009 + Threadsicher + Grafische Elemente (https://www.delphipraxis.net/136139-delphi-2009-threadsicher-grafische-elemente.html)

AJ_Oldendorf 24. Jun 2009 08:04


Delphi 2009 + Threadsicher + Grafische Elemente
 
Hallo zusammen,
ich habe nur mal eine theoretische Frage.
Unter Delphi 2006 läuft unser Projekt ohne Probleme (es sind ca. 600.000 Quelltextzeilen deswegen poste ich hier kein Source :-) ).
Unter Delphi 2009 habe ich hin und wieder das Problem, dass sich meine VCL aufhängt und kurz vorher noch eine Exception zu sehen ist.
Ich vermute jetzt einfach mal, dass es ein unerlaubter VCL Zugriff aus einem Thread ist.
Dabei handelt es sich allerdings um das gleiche Projekt, welches unter D2006 funktioniert.

Weiß jemand von euch, ob sich unter D2009 irgendwelche Sachen die mit grafischen Elementen einen Zusammenhang haben, an der Threadsicherheit etwas geändert hat?
Beispiel: Aus einem Thread darf man ja nicht auf ein Canvas zeichnen wenn es nicht Synchronize aufgerufen wurde.

Ich hoffe ihr versteht mein Problem.
Würde nur erstmal theoretisch darüber nachdenken ob sich da was geändert hat bevor ich mich in die Tiefen debuggen muss :-)

Viele Grüße
Alex

jaenicke 24. Jun 2009 08:38

Re: Delphi 2009 + Threadsicher + Grafische Elemente
 
Ganz klar: Aus einem Thread heraus darf man niemals direkt ohne Synchronisierung auf VCL-Komponenten zugreifen. Wenn sowas funktioniert, dann nur zufällig. Denn die VCL ist nicht threadsicher, egal ob bei Delphi 2006 oder 2009...

Heißt: Immer synchronisieren, dann gibt es damit auch keine Probleme. Daran hat sich auch bei Delphi 2009 nicht weiter etwas geändert. ;-)

AJ_Oldendorf 24. Jun 2009 08:41

Re: Delphi 2009 + Threadsicher + Grafische Elemente
 
Ja, dass weiß ich und habe ich auch im Programm so gemacht.
Leider verhält sich das Programm unter Delphi 2009 anders wie unter Delphi 2006.
Deswegen wollte ich wissen, obs da irgendwelche Unterschiede gibt außer jetzt mal die Unicode-String-Geschichte zu erwähnen.

Viele Grüße
Alex

Bernhard Geyer 24. Jun 2009 08:43

Re: Delphi 2009 + Threadsicher + Grafische Elemente
 
Zitat:

Zitat von AJ_Oldendorf
Ich vermute jetzt einfach mal, dass es ein unerlaubter VCL Zugriff aus einem Thread ist.
Dabei handelt es sich allerdings um das gleiche Projekt, welches unter D2006 funktioniert.

Dann hast du unter D2006 einfach nur sehr viel Glück das es dort nicht kracht. GDI-Ressourcen haben eine Thread-Affinität. D.h. sie dürfen nur aus dem erzeugenden Thread aus verwendet werden. Die VCL hat hier keinerlei Vorkehrungen getroffen um diesen Umstand vor dem Entwickler zu kapseln.

Blup 24. Jun 2009 09:05

Re: Delphi 2009 + Threadsicher + Grafische Elemente
 
Im interenen Ablauf von Synchronize hat sich in den letzten Delphiversionen schon etwas geändert.
Insbesondere werden Synchronize-Anforderungen jetzt mit höherer Priorität bearbeitet als Windows-Nachrichten.
Ob es speziell zwischen D2006 und D2009 Unterschiede gibt, kann ich allerdings nicht sagen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 01: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