Synchronisierung von Threads

P@u1

Aktives Mitglied
Hallo zusammen,

beim Arbeiten mit thraeds bin ich auf ein paar Fragen gestoßen:
1. nehmen wir an ich habe einen integer der mit dem wert 5 initialisiert wird.
Dann nehme ich einen neuen thread, der den wert der variable auf 100 setzt.
Ungefähr gleichzeitig liest ein anderer thread den wert der variablen.
Ist dann garantiert, dass entweder 5 oder 100 rauskommt, oder kann auch ein ganz anderer wert herauskommen, falls mitten beim bit setzen unterbrochen wurde (falls das denn geht)?

2. Hat es irgendeinen Sinn zu synchronisieren durch locks oder volatile oder so, bei einem boolean?
Ich habe mir dazu folgendes überlegt:
erstmal ohne locks o.ä.:
thread 1 setzt einen boolean um, thread 2 liest ungefähr gleichzeitig, dann kommt entweder true oder false heraus, kann bedes passieren

Dann das selbe mit lock:
Thread 1 holt einen lock und setzt den boolean um und öffnet den lock danach, ungefähr gleichzeitig versucht thread 2 den lock zu setzen und auszulesen und den lock dann zu öffnen.
Also wurde die Problematik von wer zuerst liest/schreibt nur auf wer zuerst den lock holt verschoben, wie ich das sehe bringt in diesem fall ein lock nichts.
Wie seht ihr das?

3. Wird bei Verwendung von volatile "optimiert"?
Ich meine zum Beispiel folgendes:
Java:
public volatile ArrayList<Integer> al;
//hat irgendnen Inhalt jetzt
for(int i : al)
{
   //tu irgendwas
}
Wir dort der lock zwischem jeden schleifendurchlauf verlassen und neu geholt, oder wird das so gemacht, dass der lock für alle durchläufe geschlossen bleibt?

So, das wars erstmal.
Vielen Dank schonmal für eure Antworten.
 

tagedieb

Top Contributor
1. Wenn du atomare Operationen verwendest wirst du entweder 5 oder 100 erhalten. Eine Zuweisung ist atomar.
Sowas wie: i = i+1; ist nicht atomar, sondern 2 Operationen read und write.

2. Wenn du dich mit Threads nicht sogut auskennst empfehle ich dir synchronized zu verwenden, ansonsten kann es sehr leicht kompliziert werden.
Atomare Operationen auf Variablen koennen mitteln Volatile geloest werden. Nichtatomare Operationen sollten synchronisiert werden.

3. Volatile optimiert den Code
Jeder Thread hat seinen eigenen Heap. Erst bei Synchronized wird die Variable von Thread ins Shared Memory synchronisiert.
Volatile haelt die Variable direkt im Shared Memory. Wenn du weder Volatile oder Synchronized verwendest kann es sein, dass ein Thread eine Variable aendert, der andere Thread diese aber nicht 'sehen' kann, da nicht synchronisiert wurde.
 

tagedieb

Top Contributor
Multithreading ist nicht so einfach und da kann man schnell was falsch machen.
Am Anfang wuerde ich mich einfach auf den Gebrauch von synchronized beschraenken.

Wenn du Zeit hast kannst du dich auch hier ins Thema einlesen Concurrency in Practice.


Wenn du nur eine Liste synchronisieren musst kannst du auch einfach eine synchronizedList erzeugen:
Java:
List<Integer> synchronizedList = java.util.Collections.synchronizedList(a1);

Somit ist der Zugriff auf die Liste threadsafe. Die Integer Klasse ist immutable, also auch threadsafe.
Benutzt du mutierbare Objekte muss der Zugriff auf diese Objekte auch threadsafe gemacht werden.
 
B

bygones

Gast
1. Wenn du atomare Operationen verwendest wirst du entweder 5 oder 100 erhalten. Eine Zuweisung ist atomar.
Sowas wie: i = i+1; ist nicht atomar, sondern 2 Operationen read und write.
sind doch 3.... lesen, erhöhen, schreiben.

Atomare Operationen auf Variablen koennen mitteln Volatile geloest werden. Nichtatomare Operationen sollten synchronisiert werden.
bzw AtomInteger oder so nutzen...
 

P@u1

Aktives Mitglied
Nochmal zum sichergehen:
Gucken wir uns folgendes Beispiel an:
Wir haben zwei erzeugte ArrayList-Objekte, nennen wir sie al1 und al2.
Außerdem haben wir eine public variable, die eine ArrayList ist, also eine Referenz auf eine Arraylist speichert.
Jetzt haben wir einen thread, der den wert dieser variablen immer zwischen den beiden ArrayList objekten hin und her tauscht.
Ein anderer Thread liest diese variable ab und zu, wir benutzen keine synchronisierung, wenn dann nur volatile.
Ist dann sichergestellt, dass der lese-Thread immer entweder eine Referenz auf al1 oder al2 ausliest, oder kann es passieren, dass eine ungültige Referenz ausgelesen wird, weil der schreibthread mitten im schreiben der refernz unterbrochen wurde?

Ich vermute stark, dass bei der Zuweisung nicht unterbrochen werden kann.
Allerdings frage ich mich dann, warum es die Klasse AtomicReference gibt, die eine Methode set hat, die wenn meine Vermutung zutrifft dann doch überflüssig wäre, oder?
 

tagedieb

Top Contributor
Wenn du nur die Methoden .get() und .set(V) von AtomicReference verwendest kannst du
Code:
volatile
verwenden.
Aber die AtomicReference Klasse bietet ja auch noch complexere Methoden an.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Problem mit der Synchronisierung von Threads Allgemeine Java-Themen 15
T Eclipse Synchronisierung mit Github Allgemeine Java-Themen 9
F Threads synchronisierung des Zugriffes auf daten Allgemeine Java-Themen 4
A Problem mit Synchronisierung Allgemeine Java-Themen 10
Kr0e Java, Concurrency und Synchronisierung Allgemeine Java-Themen 4
rode45e Java Threads Allgemeine Java-Themen 4
M Threads Allgemeine Java-Themen 1
L Threads Threads in Chatroom Allgemeine Java-Themen 30
berserkerdq2 run-methode eines Threads so programmieren, dass 30x die Sekunde etwas ausgeführt wird. Allgemeine Java-Themen 44
berserkerdq2 Threads, wie genau läuft das in Java ab? (Ich kann Threads erstellen und nutzen, nur das Verständnis) Allgemeine Java-Themen 6
CptK Backpropagation parallelisieren: Kommunikation zwischen den Threads Allgemeine Java-Themen 7
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
W Wieviele Threads sind sinnvoll? Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
T Multithreading: Wie viele Threads sollte ich erstellen? Allgemeine Java-Themen 12
G Threads vom Mainprogramm steuern Allgemeine Java-Themen 8
S BlockingQueue mit dynamischer Anpassung der Anzahl von Producer und Consumer Threads Allgemeine Java-Themen 1
x46 Threads Threads anhalten Allgemeine Java-Themen 1
J Threads verbessern die Performance NICHT ? Allgemeine Java-Themen 8
W Threads Problem Allgemeine Java-Themen 15
T Threads Tic Tac Toe mit Threads Allgemeine Java-Themen 1
M Threads über Kommandozeile Allgemeine Java-Themen 5
mrbig2017 Threads Chat Programm mit Threads? Allgemeine Java-Themen 2
J Threads - java.lang.IllegalThreadStateException Allgemeine Java-Themen 6
J Internet Broswer in Threads öffnen Allgemeine Java-Themen 1
B Threads Multithreading Threads sollen warten Allgemeine Java-Themen 12
N 1000 MQTT Messages die Sekunde - 1000 Threads erstellen ? Allgemeine Java-Themen 10
D Threads Parallel laufende Threads Allgemeine Java-Themen 4
J Unvorhersehbares Verhalten - benutze ich die falsche Bedingungsprüfung oder brauche ich Threads? Allgemeine Java-Themen 12
D Eine Forschleife mit Threads abarbeiten um es zu schneller zu machen. Ist das möglich? Allgemeine Java-Themen 20
S Wie kann ich eine kleine Stelle in meinem Code mit multiplen Threads abarbeiten..? Allgemeine Java-Themen 20
P Threads Parallelisierte DB-Abfragen mit variabler Anzahl an Threads Allgemeine Java-Themen 4
J Threads Threads Allgemeine Java-Themen 9
Viktim Threads Liste In unterschiedlichen Threads bearbeiten Allgemeine Java-Themen 23
E Threads Ausführung in Threads ist langsamer als ohne Threads Allgemeine Java-Themen 13
A Anzahl an Threads Systemweit Allgemeine Java-Themen 2
Tausendsassa Input/Output Problem mit der gleichzeitigen Ausgabe zweier Threads Allgemeine Java-Themen 8
S Alle Methodenaufrufe eines Threads notieren..? Allgemeine Java-Themen 7
M Threads JPanel eingeforen mit Threads Allgemeine Java-Themen 2
F Threads Allgemeine Java-Themen 6
F Threads Allgemeine Java-Themen 2
M Sinn von Threads? Allgemeine Java-Themen 1
J Wie erschaffe ich einen sicheren Datenaustausch zwischen Thread und Nicht-Threads Allgemeine Java-Themen 8
L Abfragen ob Threads fertig Allgemeine Java-Themen 3
P Threads Java Zugreifen Allgemeine Java-Themen 6
K Problem: Java-Klasse mit mehreren Threads als eigenen Prozess starten Allgemeine Java-Themen 3
K KeyEvent in Threads Allgemeine Java-Themen 11
V Threads Weshalb funktionieren meine Threads nicht? Allgemeine Java-Themen 2
Thallius Speicherverhalten von Properties und mehreren Threads Allgemeine Java-Themen 5
L Threads beenden Allgemeine Java-Themen 4
P Threads Threads nicht gleichzeitig starten Allgemeine Java-Themen 3
S Threads Threads werden nicht beendet Allgemeine Java-Themen 2
S Start des zweiten Threads erst nach Beenden des ersten Threads Allgemeine Java-Themen 13
N Threads statische Methoden in Threads Allgemeine Java-Themen 5
P 4 Threads in einer Methode Allgemeine Java-Themen 2
M Eclipse Mehrere Threads, mehrere Konsolen Allgemeine Java-Themen 4
OnDemand Threads und synchronized Allgemeine Java-Themen 9
R LinkedList und Threads: Strukturprobleme bez. löschen von Elementen Allgemeine Java-Themen 3
R LinkedList und Threads - welche Methode ist besser? Allgemeine Java-Themen 2
OnDemand Threads und synvhronized Allgemeine Java-Themen 2
S Problem mit Threads Allgemeine Java-Themen 1
W Threads Threads warten lassen Allgemeine Java-Themen 5
H Optimierung durch Threads Allgemeine Java-Themen 31
B Threads halten sich irgendwie auf... Allgemeine Java-Themen 6
M Threads Allgemeine Java-Themen 8
K JNI: Methoden aus unterschiedlichen Threads aufrufen Allgemeine Java-Themen 3
A Applet Alle Threads beim schließen des Applets beenden Allgemeine Java-Themen 8
R SecurityManager für einzelne Klassen/Threads? Allgemeine Java-Themen 38
O Threads und If Befehle Allgemeine Java-Themen 7
P Threads abwechseln lassen mit wait() und notify() Allgemeine Java-Themen 2
H Sehr viele Threads effizient Verwalten Allgemeine Java-Themen 13
C Threads und Exceptions Allgemeine Java-Themen 7
H java.lang.OutOfMemoryError bei der wiederholten Erzeugng von Threads Allgemeine Java-Themen 8
S Threads Abarbeitungsstatus von Threads in Datei schreiben Allgemeine Java-Themen 2
M Zugriff zweier Threads auf diesselbe Methode Allgemeine Java-Themen 16
E Threads Sudoku Threads Allgemeine Java-Themen 8
M Java Threads - Wait Notify - Verständnisproblem Allgemeine Java-Themen 5
Gossi Threads mit unterschiedlichen Aufgaben in einer Klasse? Allgemeine Java-Themen 9
G Threads Ablauf von Threads im Spezialfall Allgemeine Java-Themen 4
V Threads bei quadcore Allgemeine Java-Themen 10
V 1000 Threads oder Iterativ? Allgemeine Java-Themen 11
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
B Threads Game of Life - Threads Allgemeine Java-Themen 49
R Threads Exceptions von Threads abfangen im ThreadPool Allgemeine Java-Themen 5
S Threads Ende sämtlicher Threads abwarten Allgemeine Java-Themen 6
S Frage zu Threads (Sichtbarkeit und Verhalten) Allgemeine Java-Themen 11
M Java-Threads und Datentypen-Zugriffe Allgemeine Java-Themen 7
P Threads- Programming Allgemeine Java-Themen 2
G Threads Klasse Sound und Threads bleiben hängen Allgemeine Java-Themen 4
C Threads Zwei Threads greifen auf LinkedList zu. Allgemeine Java-Themen 12
M OutOfMemoryError in nebenläufigen Threads Allgemeine Java-Themen 6
M Threads dauerhafte bewegung mit threads Allgemeine Java-Themen 11
frankred Threads Auf eine Gruppe von Threads warten Allgemeine Java-Themen 11
J Eure Meinung: Threads verwenden, oder nicht? Allgemeine Java-Themen 6
K Warum wartet diese Funktion auf beenden des Threads? Allgemeine Java-Themen 3
F Mehrere Threads - ein Stack Allgemeine Java-Themen 6
O Wie kann ich das Ende eines Threads melden? Allgemeine Java-Themen 7
J Writer und Threads Allgemeine Java-Themen 2
G mehrere Threads starten/stoppen Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben