Das alte Lied: Parallele Systeme sind schwer zu programmieren
- Abschnitt betreten
- TDatensatz in der Liste finden
- Grafisch darstellen
- Abschnitt verlassen
Enthält der Datensatz Referenzen oder ist besonders groß? Wenn nicht, würde ich eine andere Vorgehensweise vorschlagen:
- Abschnitt betreten
- TDatensatz in der Liste finden
- Abschnitt verlassen
- Grafisch darstellen
Kritische Abschnitte sollten so klein wie möglich sein. Das Zeichnen dauert vermutlich sogar länger als eine typische Listenoperation.
Dies ließe sich noch verbessern:
Code:
datensatz = tKlassenObjekt.findeDatensatz(...);
stelleDar(datensatz);
Die CriticalSection und die Liste bleiben dabei privat und alles ist schön gekapselt.
Schöner wäre noch, wenn du für die Liste eine Klasse schreibst, die solche Funktionen wie
findeDatensatz und
einfuegeDatensatz threadsicher bereitstellt. Das sorgt dann dafür, dass du dich im Hauptthread sowie im andere Thread nicht mehr um die Threadsicherheit kümmern musst.
Wenn die Datensätze zu groß oder zu kompliziert zum Kopieren sind, dann könntest du mit Referenzzählung arbeiten.
Das sollte natürlich auch alles threadsafe und deadlockfrei passieren