Thread-Problem, und synchronized bringt nix

Status
Nicht offen für weitere Antworten.

Rock Lobster

Bekanntes Mitglied
Servus,

kann mir jemand in 2 - 3 Sätzen erklären, was genau das synchronized-Statement eigentlich bewirken soll? Meine bisherige Auffassung war eigentlich immer, daß Code, der sich in einem synchronized-Block befindet, von keinem anderen Thread unterbrochen werden kann und somit am Stück ausgeführt wird, also so, als gäbe es in diesem Moment keine anderen Threads.

Das Problem ist allerdings, daß ich noch nie das Gefühl hatte, daß mir ein synchronized-Block was bringt, denn immer wenn ich einen einsetzen will, um einen Thread-Fehler zu vermeiden, ist die Wirkung gleich null.

Mein konkretes Problem sieht zur Zeit so aus:
- eine Klasse besitzt einen Thread, der hin und wieder über eine Liste von Listenern iteriert, um diese zu benachrichtigen.
- die Klasse besitzt auch eine addListener()-Funktion, die einen Listener in die Liste einträgt.
- je nachdem wie der Mond grad steht ;) passiert beides gleichzeitig, und das ist dann natürlich problematisch, da die Iteration es nicht gerne sieht, wenn da einer einen neuen Listener reinwirft.

Jetzt war meine Idee, die Iterationen einfach in einen synchronized-Block zu setzen, aber das bringt wie gesagt überhaupt nix. Möglicherweise ist eben mein Verständnis von synchronized irgendwie falsch, oder meine Java VM will sich nicht so recht dran halten ;)

Also - wofür ist synchronized gut, und wie kann ich das Problem am elegantesten lösen?
Meine Idee wäre nun eine temporäre Liste als Zwischenlager zu erstellen, aus der sich der Thread immer dann, wenn er grad nicht mehr am iterieren ist, die neuen Objekte holt und in die eigentliche Hauptliste einfügt. Aber vielleicht geht das ja auch schöner?
 
S

SlaterB

Gast
synchronized bewirkt NICHT, dass, solange ein Thread ein Stück Code abgearbeitet, alle anderen Threads gestoppt werden,

synchronized bewirkt, dass, solange ein Thread ein Stück Code abgearbeitet, kein anderer Thread den gleichen Code-Block betreten darf

dieses Verbot gilt auch für alle anderen synchronized-Blöcke auf den gleichen Monitor

--------
wenn du also nur die Iteration synchronizierst, bewirkt das höchstens, dass niemand anders auch iterieren darf,
da das eh kein anderer macht, ist das recht nutzlos,

du musst auch das Einfügen auf synchronized setzen, und zwar mit dem gleichen Monitor,
dann ist der gegenseitige Ausschluss erreicht

Code:
class A {
  private List l;
  
  public synchronized void addSometingToList() {
  }

  public synchronized void doSometingWithList() {
  }


}
granatensicher


------

schlecht/ unsinnig wäre übrigens

public synchronized List getList() {
}

also die Liste synchronisiert abzufragen, dann aber in unsicherem Code zu durchlaufen
 

Rock Lobster

Bekanntes Mitglied
Okay, das funktioniert, vielen Dank.
Endlich hat es mal "Klick" gemacht ;)

In Deinem Beispiel setzt Du ja die gesamte Methode auf synchronized - was wird dann als Monitor hergenommen? Und ist es prinzipiell immer richtig, z.B. das betroffene Objekt (in meinem Fall die Liste) als Monitor anzugeben? Oder gibt es da auch andere Möglichkeiten?
 

hupfdule

Top Contributor
Rock Lobster hat gesagt.:
In Deinem Beispiel setzt Du ja die gesamte Methode auf synchronized - was wird dann als Monitor hergenommen?
Das Objekt, in dem sich die Methode befindet. In diesem Beispiel A.
Und ist es prinzipiell immer richtig, z.B. das betroffene Objekt (in meinem Fall die Liste) als Monitor anzugeben?

Ja, das wäre korrekt.
 
S

SlaterB

Gast
das A-Objekt wird in diesem Fall gewählt,

was sinnvoll ist hängt von der Situation ab, in deinem Beispiel scheint mir list sehr sinnvoll,
dann wäre es z.B. möglich, noch andere Teilbereiche (list2, list3) unabhängig von der ersten list zu synchronisieren,

Synchronisation auf das A-Objekt ist dagegen praktisch, wenn man viele Exemplarvariablen gleichzeitig bearbeitet
(wobei man sich auch auf einen bestimmten Monitor von diesen Variablen einigen könnte),
die elegante Syntax ist auch nicht zu verachten
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
A Thread.sleep Problem Allgemeine Java-Themen 2
Flynn Thread-Problem... Allgemeine Java-Themen 2
K Thread Problem Allgemeine Java-Themen 6
E Threads linkedlist/multi-thread problem Allgemeine Java-Themen 3
vandread Problem bei kleiner Thread-Übung Allgemeine Java-Themen 2
J Problem mit der Thread Programmierung Allgemeine Java-Themen 2
S Thread - Problem Allgemeine Java-Themen 5
D Form mit StatusFeld (Thread problem) -gelöst- Allgemeine Java-Themen 4
G Problem mit Thread! Allgemeine Java-Themen 2
E Java.net und Thread-Problem Allgemeine Java-Themen 2
R Problem mit JNI und Thread Allgemeine Java-Themen 3
S Problem!Thread! Allgemeine Java-Themen 3
M Thread Problem Allgemeine Java-Themen 7
A Problem mit Bildgenerierung in Thread Allgemeine Java-Themen 3
B Problem bei Thread Allgemeine Java-Themen 2
G thread-problem Allgemeine Java-Themen 7
bernd Thread-Problem Allgemeine Java-Themen 9
A Problem mit Thread Allgemeine Java-Themen 2
K Thread-Problem Allgemeine Java-Themen 3
B Ressourcenleck durch (virtuellen/echten) Thread Allgemeine Java-Themen 11
B Generator mit virtuellem Thread Allgemeine Java-Themen 62
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
smarterToby Wie stoppe ich diesen Thread Allgemeine Java-Themen 4
J Thread started nur einmal Allgemeine Java-Themen 19
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
OnDemand Logfile pro User / Thread Allgemeine Java-Themen 7
OnDemand Thread / Service abbrechen Allgemeine Java-Themen 3
Thallius Ist meine static Helper Class Thread save? Allgemeine Java-Themen 9
P Swing Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: npoints > xpoints.length || npoints > ypoints.length Allgemeine Java-Themen 5
B Thread.sleep() in EJB Container wie lösen? Allgemeine Java-Themen 11
S Ist das Neuzuweisen von Feldern atomic und damit Thread-Safe? Allgemeine Java-Themen 2
S Exception in thread "main" java.lang.NullPointerException at FamilienApp.main(FamilienApp.java:15) Allgemeine Java-Themen 1
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
E HILFE !! Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/io/FileUtils Allgemeine Java-Themen 4
G Thread-Programmierung Allgemeine Java-Themen 5
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
G Beendet sich der Thread selbst?! Allgemeine Java-Themen 3
mrbig2017 Sleep wird ignoriert und der Thread wartet nicht Allgemeine Java-Themen 1
S Thread beenden Allgemeine Java-Themen 9
M Array aus Thread Objekten erstellen Allgemeine Java-Themen 2
Aruetiise Swing JOptionPane ohne denn Thread zu pausieren Allgemeine Java-Themen 1
M Nanosekunden-Pause innerhalb einen Thread-Loops Allgemeine Java-Themen 3
E Thread Exception Allgemeine Java-Themen 6
javaerd Binomialkoeffizient ausrechnen, Exception in thread "main" java.lang.StackOverflowError Allgemeine Java-Themen 6
T Merkwürdiges Thread-Verhalten Allgemeine Java-Themen 6
W Thread sleep 30 sekunden - wenn keine Antwort bis dahin neu senden Allgemeine Java-Themen 2
H Thread bleibt stehen bei jar in jar Allgemeine Java-Themen 1
J Threads HTTP Request (Thread) dauert lange - in Android Allgemeine Java-Themen 3
F CPU Last eines Thread ausfindig machen Allgemeine Java-Themen 0
V Compiler-Fehler Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: Index: 125, Size: 125 Allgemeine Java-Themen 11
Tausendsassa Threads Einen Thread sich selbst schließen lassen Allgemeine Java-Themen 17
P Threads BufferedImage, Thread Concurrency Allgemeine Java-Themen 1
M Klasse in separaten Thread ausführen.Wie genau? Allgemeine Java-Themen 2
llabusch Thread blockiert Dialog Allgemeine Java-Themen 1
J Thread wait() Allgemeine Java-Themen 2
V Thread.sleep und InterruptedException? Allgemeine Java-Themen 1
G Thread nicht von GC zerstört Allgemeine Java-Themen 6
J Wie erschaffe ich einen sicheren Datenaustausch zwischen Thread und Nicht-Threads Allgemeine Java-Themen 8
Sogomn Thread blocken bis Taste gedrückt Allgemeine Java-Themen 5
T Starten vom Thread Allgemeine Java-Themen 3
T Wait/Notify() bei Thread Allgemeine Java-Themen 6
J Exception in thread "main" java.lang.NoClassDefFoundError Allgemeine Java-Themen 4
M Exception in thread "AWT-EventQueue-0" Allgemeine Java-Themen 6
Q Thread wacht nicht auf Allgemeine Java-Themen 7
T Fragen zum Thread-Thema Allgemeine Java-Themen 4
T Threads Input/Output im Thread - Datei ohne Inhalt Allgemeine Java-Themen 1
T Fragen zum Thread-Thema Allgemeine Java-Themen 9
C Threads Variablen in einem Thread Aktualisieren Allgemeine Java-Themen 17
U Thread beenden Allgemeine Java-Themen 3
W Threads Mit Thread und Runtime externe Programme öffnen Allgemeine Java-Themen 0
N Thread interrupt Status debuggen Allgemeine Java-Themen 6
A Thread: Code paralell ausführen in mehreren Instanzen Allgemeine Java-Themen 1
B Erkennen, wann Prozess beendet ist, dann Thread beenden. Allgemeine Java-Themen 6
A Thread Fehler absichtlich provozieren Allgemeine Java-Themen 3
B Threads Java Thread kommunizieren Allgemeine Java-Themen 12
N Thread Sicherheit im komplexen Datenmodell Allgemeine Java-Themen 7
K Thread richtig benutzen Allgemeine Java-Themen 3
K Exception in thread "AWT-EventQueue-1" Allgemeine Java-Themen 2
G Thread erzeugt nicht plausible NullPointerException Allgemeine Java-Themen 7
H Netbeans Warning bei Thread.sleep in Schleife Allgemeine Java-Themen 4
P [Thread] Scheint nicht Sequenziell zu Arbeiten Allgemeine Java-Themen 9
A eine test thread.join() frage Allgemeine Java-Themen 2
tuttle64 Verständnisprobleme mit Thread Locks Allgemeine Java-Themen 4
G Threads Thread bei Datenabfrage Allgemeine Java-Themen 3
S Thread anhalten per Button ? Allgemeine Java-Themen 3
E Thread Programmierung Allgemeine Java-Themen 2
S Threads ServerSocket-Thread soll schlafen, bis er gebraucht wird Allgemeine Java-Themen 2
V Thread schneller stoppen Allgemeine Java-Themen 2
V anstatt thread.join() einfach while schleife? Allgemeine Java-Themen 8
B Mausbewegung im Thread erkennen (hoch/runter) Allgemeine Java-Themen 6
G Linux/C++/Pthreads auf JVM zugreifen, thread safe? Allgemeine Java-Themen 10
K Threads Probleme mit Thread Allgemeine Java-Themen 13
K Threads Thread überprüfen Allgemeine Java-Themen 3
Z Threads Thread für einen Client Allgemeine Java-Themen 9
M Thread JavaFish Allgemeine Java-Themen 10
G Thread.sleep Allgemeine Java-Themen 12
M Threads Viele Aufrufe aus Thread, komisches Verhalten Allgemeine Java-Themen 8
B Threads Main Thread warten auf abgebrochen Task warten lassen Allgemeine Java-Themen 25
K Timer Thread Allgemeine Java-Themen 8

Ähnliche Java Themen

Neue Themen


Oben