AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi TList<T>, TQueue<T>, TDictionary<T> Threadsafe?
Thema durchsuchen
Ansicht
Themen-Optionen

TList<T>, TQueue<T>, TDictionary<T> Threadsafe?

Ein Thema von Win32.API · begonnen am 20. Jan 2010 · letzter Beitrag vom 21. Jan 2010
Antwort Antwort
Seite 1 von 2  1 2      
Win32.API

Registriert seit: 23. Mai 2005
312 Beiträge
 
#1

TList<T>, TQueue<T>, TDictionary<T> Thread

  Alt 20. Jan 2010, 15:52
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
  Mit Zitat antworten Zitat
Benutzerbild von igel457
igel457

Registriert seit: 31. Aug 2005
1.622 Beiträge
 
FreePascal / Lazarus
 
#2

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

  Alt 20. Jan 2010, 16:44
So lange du nur lesend Zugriff auf eine Datenstruktur hast ist diese - außer die Implementierung ist nicht gut und schreibt z.B. in Variablen der Klasse/Unit und nicht in lokale Variablen auf dem Stack - immer Threadsicher.
Andreas
"Sollen sich auch alle schämen, die gedankenlos sich der Wunder der Wissenschaft und Technik bedienen, und nicht mehr davon geistig erfasst haben als die Kuh von der Botanik der Pflanzen, die sie mit Wohlbehagen frisst." - Albert Einstein
  Mit Zitat antworten Zitat
Win32.API

Registriert seit: 23. Mai 2005
312 Beiträge
 
#3

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

  Alt 20. Jan 2010, 17:03
Genau, da ich aber den Source fuer die Generics nicht besitze wuerde ich es gerne von jemandem bestaetigt haben, der sich damit schon mal auseinander gesetzt hat.

Grueße,
Win32.API
  Mit Zitat antworten Zitat
jbg

Registriert seit: 12. Jun 2002
3.483 Beiträge
 
Delphi 10.1 Berlin Professional
 
#4

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

  Alt 20. Jan 2010, 18:34
Zitat von Win32.API:
Genau, da ich aber den Source fuer die Generics nicht besitze
Wie denn das? Alle Editionen kommen mit dem Quellcode der RTL und VCL.
  Mit Zitat antworten Zitat
Benutzerbild von igel457
igel457

Registriert seit: 31. Aug 2005
1.622 Beiträge
 
FreePascal / Lazarus
 
#5

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

  Alt 20. Jan 2010, 19:40
TList etc. verwalten intern ein Array. Beim (lesenden) Zugriff auf "Items" wird nur der Inhalt des Arrays zurückgegeben, sonst wird nichts gemacht. Lesender Zugriff auf TList und Verwandte davon ist Threadsicher.
Andreas
"Sollen sich auch alle schämen, die gedankenlos sich der Wunder der Wissenschaft und Technik bedienen, und nicht mehr davon geistig erfasst haben als die Kuh von der Botanik der Pflanzen, die sie mit Wohlbehagen frisst." - Albert Einstein
  Mit Zitat antworten Zitat
Win32.API

Registriert seit: 23. Mai 2005
312 Beiträge
 
#6

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

  Alt 20. Jan 2010, 20:18
Zitat von jbg:
Zitat von Win32.API:
Genau, da ich aber den Source fuer die Generics nicht besitze
Wie denn das? Alle Editionen kommen mit dem Quellcode der RTL und VCL.
Echt, seit wann denn das? Werde es mir anschauen, sobald ich wieder auf der Arbeit bin.

Zitat von igel457:
TList etc. verwalten intern ein Array. Beim (lesenden) Zugriff auf "Items" wird nur der Inhalt des Arrays zurückgegeben, sonst wird nichts gemacht. Lesender Zugriff auf TList und Verwandte davon ist Threadsicher.
Danke, da ich den Source warscheinlich doch habe, werde ich es mir zur Sicherheit nochmal anschauen.

Grueße,
Win32.API
  Mit Zitat antworten Zitat
jbg

Registriert seit: 12. Jun 2002
3.483 Beiträge
 
Delphi 10.1 Berlin Professional
 
#7

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

  Alt 20. Jan 2010, 22:20
Zitat von Win32.API:
Echt, seit wann denn das?
Seit es keine Standard bzw. Personal Edition mehr gibt. Also Seit Delphi 2006 (Auch die TurboDelphi Variante hatte den Quellcode, nur eben keinen Kommandozeilen Compiler)
  Mit Zitat antworten Zitat
mindtrap

Registriert seit: 7. Aug 2008
23 Beiträge
 
#8

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

  Alt 20. Jan 2010, 22:21
Zitat von igel457:
TList etc. verwalten intern ein Array. Beim (lesenden) Zugriff auf "Items" wird nur der Inhalt des Arrays zurückgegeben, sonst wird nichts gemacht. Lesender Zugriff auf TList und Verwandte davon ist Threadsicher.
Das ist eine gefährliche Aussage.
Wenn dein Thread die TList exklusiv verwendet ist das kein Problem.
Wird die TList allerdings von zwei Threads verwendet...
Ich habe die Implementierung momentan nicht vor mir liegen, aber TList wird nicht beim
Zugriff gesperrt.
Da die Liste vermutlich auch mit Elementen gefüllt wird (sonst ist sie sinnlos), muss also irgendetwas auch
schreibenden Zugriff haben. Und wenn dieses Etwas zufällig ein Element entfernt, während der Thread
liest, dann heißt es Daumen drücken.
Dafür gibt es extra eine Implementierung von TThreadList, welche intern eine TList verwendet und bei Zugriffen
sperrt.


Zitat von jbg:
Zitat von Win32.API:
Genau, da ich aber den Source fuer die Generics nicht besitze
Wie denn das? Alle Editionen kommen mit dem Quellcode der RTL und VCL.
Ich glaube die Personal Editions lieferten den Code nicht mit.
Aber das wird Win32.API sicherlich nicht in der Arbeit verwenden. :}
  Mit Zitat antworten Zitat
Daniel
(Co-Admin)

Registriert seit: 30. Mai 2002
Ort: Hamburg
13.920 Beiträge
 
Delphi 10.4 Sydney
 
#9

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

  Alt 20. Jan 2010, 22:29
Zitat von mindtrap:
Ich glaube die Personal Editions lieferten den Code nicht mit.
Die Kombination "Delphi" + "Generics" + "Personal Edition" hat es bis heute offiziell nicht gegeben.
Daniel R. Wolf
mit Grüßen aus Hamburg
  Mit Zitat antworten Zitat
mindtrap

Registriert seit: 7. Aug 2008
23 Beiträge
 
#10

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

  Alt 20. Jan 2010, 22:31
Stimmt, allerdings war ich auch in Gedanken nur bei dem Wort Code und nicht Generic.

Dann bin ich mir garnicht sicher, ob das auf meine Aussage bzgl. TList zutrifft. Hier geht es ja um Generic.
Ich muss mal mein Delphi wieder aktualisieren, bei D2005 gibt's keine Generics.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:25 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz