![]() |
AW: TThread: Daten von Mainthread holen --> Synchronize notwendig?
Zitat:
Also dann eher so:
Delphi-Quellcode:
procedure TMainForm.Thread_UDP_ReceiveString(var Text: String);
var S: String; begin S := ''; If idUDPClient.Connected then S := IdUDPClient.ReceiveString(-1, TEncoding.UTF8); System.TMonitor.Enter(ClientThread); try Text := S; finally System.TMonitor.Exit(ClientThread); end; end; |
AW: TThread: Daten von Mainthread holen --> Synchronize notwendig?
Ja, genau. Wie schon geschrieben:
Hier ist es nicht relevant, aber gewöhne es dir besser gleich so an. Und manchmal stellt sich dann ja auch heraus, dass eine weitere Verarbeitung gar nicht nötig ist, man den Teil mit TMonitor also gar nicht ausführen muss. Das kann man dann vorher noch prüfen. |
AW: TThread: Daten von Mainthread holen --> Synchronize notwendig?
Jupp, prinzipiell kannst du dir dieses TMonitor wie eine CriticalSection vorstellen.
Außer dass du dir dort erst eine CriticalSection-Erstellen mußt und dann CS.Enter und CS.Leave nutzt. Bei TMonitor ist dieser Speicherplatz/Instanz bereits in jedem einzelnen TObject integriert. TThread.Synchronize und TThread.Queue lassen den jeweioligen Code im Hauptthread laufen. Codes im Hauptthread sind bereits im Hauptthread und müssen natürlich nicht nochmal abgesichet werden. Somit läuft jeder Zugriff nur noch im Hauptthread, also IMMER nur jeweils einer gleichzeitig und somit gibt es keine Konflikte. SendMessage und PostMessage ... dort werden die Messages im Thread der Komponente ausgeführt (wo diese Komponente erstellt wurde) .... bei der VCL normal der Hauptthread. Also auch hier wieder alles innerhalb des selben Threads und somit sicher. Interlocked, bzw. Atomic, sowie LOCK im Assembler, blocken nur für diesen einen CPU-Befehl den Zugriff durch andere CPU-Kerne. PS: Die Referenzzählung von Interfaces, Strings (LongStrings) und dynamischen Arrays nutzt das. Und dann gibt noch brutalere Sachen ala TMREWSync/TMultiReadExclusiveWriteSynchronizer, für Dinge wo man oft liest (wenn es in sich thread-save ist) und seltener "unsicher" schreibt. Mehrere können also gleichzeitig lesen, aber sobald EINER schreiben will, warten alle Anderen so lange. Es gibt z.B. auch ThreadedList (normal oder als generic), wo man mit Add einfach "blind" reinschreiben kann (intern eine CriticalSection) und beim Auslesen mal kurz "selbst" die Liste sperrt, im gesichert auf den Inhalt zuzugreifen. Einige Implementationen bieten auch einfache Push- und Pop-Methoden, welche, wie Add, in sich abgesichert sind. Einer/mehrere Threads schieben was rein ... einer/mehrere andere Threads holen sich war raus (falls es was gibt) ... und alles automatisch abgesichert. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 19:51 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