AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen FreePascal TMREW-Synchronisierer BeginRead() reentrant bei BeginWrite() eines anderen Threads?
Thema durchsuchen
Ansicht
Themen-Optionen

TMREW-Synchronisierer BeginRead() reentrant bei BeginWrite() eines anderen Threads?

Ein Thema von MStoll · begonnen am 30. Mär 2014 · letzter Beitrag vom 31. Mär 2014
Antwort Antwort
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.533 Beiträge
 
Delphi 12 Athens
 
#1

AW: TMREW-Synchronisierer BeginRead() reentrant bei BeginWrite() eines anderen Thread

  Alt 30. Mär 2014, 22:53
Wenn ein BeginRead offen ist, dann kann der selbe Thread nochmal ein BeginRead aufrufen, genauso wie andere Threads das können.

Auch könnte ein Thread ein BeginWrite aufrufen, selbst wenn vorher ein BeginRead in diesem Thread startete.
Wobei es da auf die Implementation ankommt.
Ein BeginWrite wartet mindestens, bis alle BeginReads aus anderen Threads beendet wurden.

Aber wenn man z.B. in zwei Thread ein BeginRead ausführt und daraufhin direkt ein BeginWrite, dann könnte/wird man in einen Deadlock laufen, da beide Threads auf das Ende der
Sperren des anderen Threads warten.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.751 Beiträge
 
Delphi 12 Athens
 
#2

AW: TMREW-Synchronisierer BeginRead() reentrant bei BeginWrite() eines anderen Thread

  Alt 30. Mär 2014, 23:23
Aber wenn man z.B. in zwei Thread ein BeginRead ausführt und daraufhin direkt ein BeginWrite, dann könnte/wird man in einen Deadlock laufen, da beide Threads auf das Ende der
Sperren des anderen Threads warten.
Das sehe ich anders! Das BeginWrite entfernt zunächst den eigenen ReadLock, bevor es auf die Freigabe der anderen ReadLocks wartet. Das erlaubt dem Thread mit dem ersten BeginRead mit seinem BeginWrite durchzukommen. Dieses CodeSite-Log zeigt, daß es funktioniert:
Angehängte Grafiken
Dateityp: png MREW.png (12,1 KB, 13x aufgerufen)
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.533 Beiträge
 
Delphi 12 Athens
 
#3

AW: TMREW-Synchronisierer BeginRead() reentrant bei BeginWrite() eines anderen Thread

  Alt 31. Mär 2014, 00:35
Vielliecht wurde da mal was geändert?

Es ist zwar schon viele Jahre her, daber (vermutlich) ist damals mal ein Projekt, an soneiner Stelle, öfters mal hängen geblieben.
Jedenfalls nach einem Umbau und vorherrigem Freigeben des BeginRead, blieb es dann nicht mehr hängen.

Stellt der nach dem EndWrite das BeginRead eigentlich wieder her?
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (31. Mär 2014 um 11:47 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.751 Beiträge
 
Delphi 12 Athens
 
#4

AW: TMREW-Synchronisierer BeginRead() reentrant bei BeginWrite() eines anderen Thread

  Alt 31. Mär 2014, 07:40
Vielliecht wurde da mal was geändert?
Der Test war jetzt mit XE3.

Stellt der nach dem EndWrite das BeginWrite eigentlich wieder her?
Das BeginRead, ja!
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
MStoll

Registriert seit: 15. Nov 2005
131 Beiträge
 
Turbo Delphi für Win32
 
#5

AW: TMREW-Synchronisierer BeginRead() reentrant bei BeginWrite() eines anderen Thread

  Alt 31. Mär 2014, 12:30
Anscheinend gibt's da dann deutliche Unterschiede zwischen Free Pascal und den neueren Delphi-Versionen. Ich muss dringend mal schauen, wie Turbo Delphi das macht. Nicht, dass es da generelle, hinterlistige Inkompatibilitäten gibt.

Ich habe mir in der Zwischenzeit mal so weitergeholfen, dass ich eine Subklasse zu TMREW gebaut habe, die (durch eine eigene CriticalSection geschützt) über die Reader Buch führt und für jeden zählt, wie oft er reinkommt. Nur beim ersten Reinkommen und dem dazugehörigen Rauskommen eines Threads werden die entsprechenden BeginRead()- bzw. EndRead()-Aufrufe aus der TMREW-Klasse aufgerufen, anderenfalls die Zähler entsprechend erhöht bzw. verkleinert.

Da ich nur ein paar wenige Threads habe, die darauf zugreifen, geht das bis jetzt ganz gut.
"Man soll nie mehr essen als mit Gewalt reingeht!" (n.n.)
  Mit Zitat antworten Zitat
Antwort Antwort


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 03:43 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