Einzelnen Beitrag anzeigen

Reinhard Kern

Registriert seit: 22. Okt 2006
772 Beiträge
 
#5

Re: thread variablen zugriff - Verständnisfrage

  Alt 8. Jan 2007, 14:57
Zitat von th_bone:
Hi,

eine Verständnisfrage...

Hintergrund:

ich habe verschiedene threads die auf eine systemunabhängige Uhrzeit, die in einer globalen Variable
(tdatetime) steht, zugreifen sollen.

Die Uhrzeit wird durch einen eigenen thread sekündlich angepasst - d.h. nur dieser eine thread schreibt etwas in die globale variable.
Alle anderen greifen nur lesend auf die Uhrzeit zu...

Frage:

ist es dann eigentlich nötig den zugriff zu synchronizieren ?

kann es überhaupt passieren, dass ein thread gerade schreibt und der andere parallel die variable
ausliest, so dass ein unmöglicher Wert herauskommt
...
Ralf
Hallo Ralf,

wenn nur einer schreibt, ist das sicher, solange das Lesen und Schreiben "atomare" Operationen sind, also nicht unterbrochen werden können. Handelt es sich z.B. um einen array, der in einer Schleife beschrieben oder gelesen wird, so kann die Schreibschleife durch einen lesenden Thread unterbrochen werden und umgekehrt, in beiden Fällen entstehen inkonsistente Ergebnisse.

Ausserdem besteht immer die Möglichkeit unsauberer Programmierung (im Sinn von Mutlithreading), z.B.

Delphi-Quellcode:
if ThreadStatus = running then
  begin
  SaveStatus := ThreadStatus;
  ....
durch den 2maligen Zugriff kann der abgefragte Status inkonsistent sein, z.B. nicht mehr "running" entgegen der Voraussetzung.

Die Aussage, dass die VCL nicht "threadsicher" ist, heisst ja u.a., dass sie auf solche Probleme nicht überprüft wurde. Sicherer ist es deshalb immer, eine Synchronisation zu verwenden - bei den Synchronisationsobjekten stellt das Betriebssystem sicher, dass die Zugriffe atomar erfolgen.

Wenn es sich um die Uhrzeit in Sekunden handelt, funktioniert es deshalb ohne Synchronisation, weil ja nur diese oder die nächste Sekunde auftreten kann, und die folgt sowieso irgendwann. Beim Zurücksetzen oder Stellen sollte man sich aber schon sorgfältig überlegen, ob es keine Nebenwirkungen geben kann.

Gruss Reinhard
  Mit Zitat antworten Zitat