durch die Verwendung eines globalen TMultiReadExclusiveWriteSynchronizer und BeginWrite/EndWrite, welches ich NUR dort verwende wo ich meiner Klasseninstanz Daten zuweise, ist meine Prozedur rund 5% schneller geworden. Kann das daran liegen, dass ich nun nicht mehr rigoros alles blockiere sondern nur noch den schreibenden Zugriff?
Korrekt. Der
TMultiReadExclusiveWriteSynchronizer
ist für solche Szenarien besser geeignet, als
TCriticalSection
oder
TMonitor
. Solange jetzt n-Threads gleichzeitig NUR lesen, wirst du einen Performancevorteil feststellen können. Im Grunde stellt der
TMultiReadExclusiveWriteSynchronizer
jetzt nur noch sicher, dass erst alle lesenden Zugriffe abgeschlossen sind, bevor ein schreibender Zugriff stattfindet und blockiert während dieser Zeit dann alle lesenden Operationen (deshalb musst du trotzdem signalisieren, an welchen Stellen du lesen willst).
Mit
TCriticalSection
oder
TMonitor
hingegen, kann auch nur ein einziger Thread gleichzeitig lesen.