Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi TList<T>, TQueue<T>, TDictionary<T> Threadsafe? (https://www.delphipraxis.net/146468-tlist-t-tqueue-t-tdictionary-t-threadsafe.html)

Khabarakh 20. Jan 2010 23:22

Re: TList<T>, TQueue<T>, TDictionary<T> Th
 
Zitat:

Zitat von mindtrap
Wenn dein Thread die TList exklusiv verwendet ist das kein Problem.

Das ist natürlich eine elegante Definition von "threadsafe" :mrgreen: .
Zitat:

Zitat von mindtrap
Da die Liste vermutlich auch mit Elementen gefüllt wird (sonst ist sie sinnlos), muss also irgendetwas auch
schreibenden Zugriff haben.

Aber das kann doch auch vor dem Multithreading-Teil passieren? Zugegeben, ein Schreiber und ein/mehrere Leser ist der häufigste Fall (-> TMultiReadExclusiveWriteSynchronizer), aber die Frage ist doch relativ eindeutig gestellt.

mindtrap 21. Jan 2010 01:07

Re: TList<T>, TQueue<T>, TDictionary<T> Th
 
Zitat:

Zitat von Khabarakh
Aber das kann doch auch vor dem Multithreading-Teil passieren? Zugegeben, ein Schreiber und ein/mehrere Leser ist der häufigste Fall (-> TMultiReadExclusiveWriteSynchronizer), aber die Frage ist doch relativ eindeutig gestellt.

Dann gilt die Definition. ;)
Zitat:

Zitat von Khabarakh
Zitat:

Zitat von mindtrap
Wenn dein Thread die TList exklusiv verwendet ist das kein Problem.

Das ist natürlich eine elegante Definition von "threadsafe" :mrgreen: .


Stevie 21. Jan 2010 10:02

Re: TList<T>, TQueue<T>, TDictionary<T> Th
 
Zitat:

Zitat von Win32.API
Hallo,

sind die oben genannten Typen threadsafe, wenn man nur lesen drauf zugreift?

Z.b. mit einer Schleife alle Eintraege durchlaufen.

Grueße,
Win32.API

Nein. Und auch die nicht generische TList ist es nicht, dazu musst du TThreadList (Name ist irreführend, es handelt sich hierbei nicht um eine Liste von TThread :mrgreen:) benutzen und Lock/Unlock benutzen.

igel457 21. Jan 2010 10:53

Re: TList<T>, TQueue<T>, TDictionary<T> Th
 
Naja, die Frage war ja eindeutig nur auf lesenden Zugriff gestellt - und solange auf gemeinsam genutzen Speicher kein Schreibzugriff erfolgt, ist solcher Code immer Threadsicher.

TThreadList ist für gemischt lesenden/schreibenden Zugriff gedacht.

Und ich persönlich sehe in folgendem Codeabschnitt von TList keinen einzigen schreibenden Zugriff auf irgendeinen Speicherbereich:
Delphi-Quellcode:
function TList.Get(Index: Integer): Pointer;
begin
  if (Index < 0) or (Index >= FCount) then
    Error(@SListIndexError, Index);
  Result := FList^[Index];
end;
Also wiederhole ich nochmal: Solange mehrere Threads ausschließlich lesenden Zugriff auf TList haben, ist das Threadsicher. TThreadList wird nur benötigt, wenn irgendein Thread gleichzeitig in die Liste schreibt.

Stevie 21. Jan 2010 12:10

Re: TList<T>, TQueue<T>, TDictionary<T> Th
 
Zitat:

Zitat von igel457
Naja, die Frage war ja eindeutig nur auf lesenden Zugriff gestellt - und solange auf gemeinsam genutzen Speicher kein Schreibzugriff erfolgt, ist solcher Code immer Threadsicher.

Stimmt, ich bin davon ausgegangen, dass man nicht sicher weiß, was ein anderer Thread gerade macht (immerhin müssen ja auch irgendwo die Daten in den Listen herkommen, die man ausliest) und im eigenen Thread nur lesend zugreift und wissen möchte, ob das threadsafe ist.

Win32.API 21. Jan 2010 15:08

Re: TList<T>, TQueue<T>, TDictionary<T> Th
 
Zitat:

Zitat von Khabarakh
Zitat:

Zitat von mindtrap
Da die Liste vermutlich auch mit Elementen gefüllt wird (sonst ist sie sinnlos), muss also irgendetwas auch
schreibenden Zugriff haben.

Aber das kann doch auch vor dem Multithreading-Teil passieren? Zugegeben, ein Schreiber und ein/mehrere Leser ist der häufigste Fall (-> TMultiReadExclusiveWriteSynchronizer), aber die Frage ist doch relativ eindeutig gestellt.

Genau so passiert es, die Liste wird mit elementen gefuellt und anschließend die Threads erstellt, die nur lesend auf die Liste zugreifen.

Danke fuer die zahlreichen Antworten.


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:17 Uhr.
Seite 2 von 2     12   

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 by Thomas Breitkreuz