![]() |
TList in Thread synchronisieren (CriticalSection)
Hey,
ich habe ein kleines Problem. Und zwar habe ich eine von TThread abgeleitete Klasse, welche in einer Schleife Daten aus einer Liste bearbeitet:
Delphi-Quellcode:
Der Thread hat entsprechende Methoden, um Daten zur Liste hinzuzufügen, zu entfernen oder zu verschieben. Jetzt habe ich ein paar Fragen:
while not Terminated do
begin for I := 0 to FList.Count - 1 do begin // blabla .. end; end; :arrow: Muss ich hier die Zugriffe überhaupt synchronisieren oder regelt TList das intern? :arrow: Wenn ja, wie mache ich das am geschicktesten? Ich hatte mal testweise ein privates Feld CS: TCriticalSection angelegt, welches ich folgendermaßen innerhalb des Threads verwende:
Delphi-Quellcode:
Die Methoden zum Ändern der Liste wurden entsprechend mit Enter und Leave geklammert.
while not Terminated do
begin CS.Enter; for I := 0 to FList.Count - 1 do begin // blabla .. end; CS.Leave; end; :arrow: Das Problem war nun, dass beim Aufruf von z.B. AddData() der Main Thread dauerhaft blockiert wurde, die CriticalSection im Thread also scheinbar nie released wurde. Hat jemand da paar Tips für mich? :) Achso der Thread ist zeitkritisch. Einbauen von Sleep oder Ähnlichem ist hier keine Lösung. Viele Grüße Zacherl |
Re: TList in Thread synchronisieren (CriticalSection)
Hallo Zacherl, wenn die TList nur intern im Thread verwendet wird, brauchst Du keine Synchronisation.
Sobald ein anderer Thread auf diese Liste zugreift, musst Du synchronisieren. Für soetwas gibt es die TThreadList (sollte in Delphi auch so heissen) lg. Astat |
Re: TList in Thread synchronisieren (CriticalSection)
Ah vielen Dank, diese TThreadList sieht gut aus. Da die Methoden wie AddData(), etc. vom Main Thread aus aufgerufen werden sollen, nehme ich mal an, dass eine Synchronisation notwendig sein wird.
|
Re: TList in Thread synchronisieren (CriticalSection)
Zitat:
lg. Astat |
Re: TList in Thread synchronisieren (CriticalSection)
Danke dir, ich probier mal ob das dann besser funktioniert als mit TCriticalSection :lol:
|
Re: TList in Thread synchronisieren (CriticalSection)
Jupp, TList ist nicht threadsicher.
(Wenn auf irgendwas nur innerhalb irgendeines Threads und nur in diesem, zugegriffen wird, dann muß man nichts absichern) PS: um Daten einer Liste abzuarbeiten, hatt ich mir mal dieses gebastelt ![]() Zitat:
Delphi-Quellcode:
Denn wenn etwas passiert (z.B. eine Exception), dann wird da wirklich kein .Leave aufgerufen. :warn:
while not Terminated do
begin CS.Enter; try for I := 0 to FList.Count - 1 do begin // blabla .. end; finally CS.Leave; end; end; Und dann rufst du praktisch direkt nach dem .Leave fast sofort wieder .Enter auf. Wenn also hier Windows nicht rein zufällig an dieser Stelle eine Pause einlegt und den anderen Threads so überhaupt die Möglichkeit gibt hier einzusteigen, dann kann auch nie ein anderer Thread an der Stelle die CS "übernehmen".
Delphi-Quellcode:
0 gibt nur für einen "Zyklus" die Kontrolle ab,
while not Terminated do
begin CS.Enter; try for I := 0 to FList.Count - 1 do begin // blabla .. end; finally CS.Leave; end; Sleep(0); end; so daß die anderen Threads überhaupt 'ne Chance bekommen. Unter Umständen könnte hier aber auch eine noch längere Pause hilfreich sein. |
Re: TList in Thread synchronisieren (CriticalSection)
Danke dir für deine ausführliche Antwort. Deinen Stack werde ich mir mal ansehen, das sieht interessant aus :) Der kleine Code eben war nur ein Beispiel. Im richten Programm hatte ich natürlich mit try .. finally gearbeitet. Mit der ThreadList funktioniert es bisher auch ohne Sleep() relativ gut. Manchmal muss der Main Thread allerdings schon einige Zeit warten. Ich teste das ganze mal mit einem Sleep(0) oder Sleep(1). Das könnte von der Performance her grade noch vertretbar sein.
Edit: Mit Sleep(0) sieht es ziemlich perfekt aus :love: |
Re: TList in Thread synchronisieren (CriticalSection)
Zitat:
Zitat:
|
Re: TList in Thread synchronisieren (CriticalSection)
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:56 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