AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) Delphi Unterschied Monitor/Critical section/Mutex
Thema durchsuchen
Ansicht
Themen-Optionen

Unterschied Monitor/Critical section/Mutex

Ein Thema von Neutral General · begonnen am 4. Mär 2015 · letzter Beitrag vom 4. Mär 2015
Antwort Antwort
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#1

Unterschied Monitor/Critical section/Mutex

  Alt 4. Mär 2015, 11:59
Hallo,

Ich bin leider nicht 100%ig schlau geworden bisher. Kann mir jemand in wenigen Sätzen den Unterschied der im Titel genannten Objekte zur Synchronisation von Threads erklären?
Und für welche Anwendungsgebiete ist was am besten?

In meinem Fall geht es um ein TDictionary auf das aus mehreren Threads heraus zugegriffen werden kann. Momentan habe ich das über ein Mutex geregelt (was zu funktionieren scheint).
Aber was ist jetzt der Unterschied zu TMonitor und critical sections? Was ist in meinem Fall besser?

Abgesehen davon gibt es so viel was man bei Threads falsch machen kann. Gibt es da vllt. ein Guide o.ä. mit allem was man beachten muss?
Habe bisher nur ab und zu was mit Threads gemacht aber oft hatte ich (vllt auch unbegründet) ein schlechtes Gefühl dass mir gleich evtl. alles um die Ohren fliegt weil ich irgendwo irgendwas nicht ganz richtig gemacht hab und es dann vllt unter bestimmten Umständen knallen könnte.
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#2

AW: Unterschied Monitor/Critical section/Mutex

  Alt 4. Mär 2015, 12:56
Soweit ich weiß, sind das Synonyme. Konzeptionell kann ich zwischen den dreien jedenfalls keinen Unterschied erkennen. Mutex ist für mich die neutrale Bezeichnung, Windows nennt sie halt Critical Section, und Monitor kommt von Java.
Wozu man eine TMonitor-Klasse jetzt gerade in Delphi auch noch braucht, ist mir schleierhaft. Mein Gefühl ist schon lange, dass Embarcadero nicht genug qualifizierte Entwickler mit Delphi-Erfahrung findet und Quereinsteiger mit Java-Background einstellt. Deshalb findet man immer mehr Konzepte, die sich in Delphi wie ein Fremdkörper anfühlen. Laut diesem Blog ist TMonitor übrigens auch gleich mal um den Faktor 10 aufgeblähter und langsamer als die alten CriticalSections, wohl damit der Java-Entwickler sich auch gleich zuhause fühlt.

Ein paar Tipps zur Multithreadentwicklung: So kurze Code-Abschnitte wie möglich locken, und möglichst immer beim Aufrufer und nicht in der aufgerufenen Funktion. Als Programmierer hat man ja sonst immer die Tendenz, Komplexität durch Kapselung in Subroutinen zu verbergen. Bei kritischen Abschnitten ist das jedoch nach meiner Erfahrung kontraproduktiv. Es ist besser, wenn man direkt sieht, wo die kritischen Abschnitte verlaufen. Dadurch erkennt man eher, wo Deadlocks entstehen könnten.

Ich habe außerdem die Erfahrung gemacht, dass rekursive Mutexe zu schlechtem Code führen. Rekursiv heißt, dass man innerhalb eines Threads ein Mutex mehrfach locken und unlocken kann. (Beispiel: Mutex.Lock; Mutex.Lock; Mutex.Unlock; Mutex.Unlock; ) Bei nichtrekursiven Mutexen gäbe es dagegen beim 2. Lock-Versuch einen Deadlock (es spielt keine Rolle, dass man sich immer noch im gleichen Thread befindet). Das passiert zum Beispiel bei pthreads unter Linux und war für mich erst ungewohnt, weil ich es von Windows so kannte, dass alle Critial Sections standardmäßig rekursiv sind. Ich muss im Nachhinein aber sagen, dass ich weniger Probleme habe, seit ich mit nichtrekursiven Mutexen arbeite, weil man so gezwungen ist, besser über das Problem nachzudenken. Man kann alles, was man mit rekursiven Mutexen machen kann, auch ohne machen, und die Lösung ist am Ende sauberer.
  Mit Zitat antworten Zitat
SMO

Registriert seit: 20. Jul 2005
178 Beiträge
 
Delphi XE6 Professional
 
#3

AW: Unterschied Monitor/Critical section/Mutex

  Alt 4. Mär 2015, 13:39
Für Windows gilt: Critical Sections sind schneller als ein Mutex, aber dafür nicht global. Eine CS ist kein Kernelobjekt (hat ja auch kein Handle), erfordert deswegen keinen langsamen Kontextwechsel vom User Mode in den Kernel Mode. Jedenfalls wenn die CS nicht gesperrt ist. Eine CS kann nur für Threads innerhalb ein und desselben Prozesses benutzt werden. Ein Mutex dagegen ist ein Kernelobjekt, erfordert deshalb immer einen Kontextwechsel, kann dafür aber auch global über mehrere Prozesse hinweg benutzt werden.

Zu TMonitor kann ich nichts sagen.
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.646 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Unterschied Monitor/Critical section/Mutex

  Alt 4. Mär 2015, 14:05
TMonitor ist oft die schnellste Variante, da zuerst ein paar Spins versucht werden, ob es nicht vielleicht schon gleich funktioniert bevor die teure Variante (gemessen an Rechenzeit) mit WaitFor... Funktionen der API (WaitForSingleObject z.B., hab nicht geschaut was verwendet wird) benutzt wird.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.176 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: Unterschied Monitor/Critical section/Mutex

  Alt 4. Mär 2015, 14:21
Hat man TMonitor nicht eine katastrophale Performance nachgesagt bis sich dessen in XE5 angenommen wurde?

Auf jeden Fall hier ein bisschen Stoff: http://www.delphitools.info/2013/06/...iticalsection/
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.646 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: Unterschied Monitor/Critical section/Mutex

  Alt 4. Mär 2015, 15:34
Das stimmt, das bezog sich auf die aktuellen Versionen. Aber man kann ja den SpinCount auch manuell jeweils setzen. Das ist eine der Änderungen, die das ganze schneller gemacht hat.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
Benutzerbild von stoxx
stoxx

Registriert seit: 13. Aug 2003
1.111 Beiträge
 
#7

AW: Unterschied Monitor/Critical section/Mutex

  Alt 4. Mär 2015, 18:18
Den Spincount kann man übrigens auch bei Critical Sections einstellen / ändern.

"InitializeCriticalSectionAndSpinCount"

https://msdn.microsoft.com/en-us/lib...(v=vs.85).aspx

Mmt TMonitor war es die einzige Möglichkeit unter Android / Firemonkey, die ich gefunden habe, einen Thread äquivalent zu Windows mit Event + WaitforSingleObject aus dem Schlafmodus sofort aufzurufen.

.
Phantasie ist etwas, was sich manche Leute gar nicht vorstellen können.

Geändert von stoxx ( 4. Mär 2015 um 18:21 Uhr)
  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 15:50 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