Threads und synchronized

Status
Nicht offen für weitere Antworten.
L

Lorus

Gast
Hallo Zusammen,

anscheint habe ich die ganze Sache noch nicht so recht verstanden.
Ich möchte 3 Threads erstellen, die eine gemeinsame Zählvariable besitzen, die synchronisiert werden soll.

Eine Ausgabe soll dann also ca. so aussehen:

Thread 1: 1
Thread 3: 2
Thread 1: 3
Thread 2: 4
Thread 3: 5
Thread 2: 6
Thread 1: 7
Thread 3: 8
Thread 2: 9
Thread 3: 10

Folgenden Code habe ich mir dazu nun gebastelt:

Code:
class Counter {
    int Counter=0;
        
    public synchronized int getCounterValue() {
        return Counter;
    }
        
    public synchronized void incrementCounter() {
        Counter++;
    }
}

class TextThread extends Thread {
    String text;

    public TextThread(String text) {
        this.text = text;
    }

    public void run() {
    
        Counter count = new Counter();

        while(count.getCounterValue() < 10) {
            count.incrementCounter();  
            try {
                sleep((int)(Math.random()*1000));
            }
            catch(InterruptedException e) { 
            }
            System.out.println(text + ": " + count.getCounterValue()); 
        }
    }
} 

class TextThreadDemo {

    public static void main(String args[]) {
        TextThread t1, t2, t3;
    
        t1= new TextThread("Thread 1");
        t2 = new TextThread("Thread 2");
        t3 = new TextThread("Thread 3");
        t1.start();
        t2.start();
        t3.start();
    }
}

Erhalte allerdings ca. folgende Ausgabe:



Thread 1: 1
Thread 3: 1
Thread 2: 1
Thread 1: 2
Thread 1: 3
Thread 3: 2
Thread 2: 2
Thread 1: 4
Thread 3: 3
Thread 1: 5
Thread 3: 4
Thread 2: 3
Thread 1: 6
Thread 1: 7
Thread 2: 4
Thread 3: 5
Thread 2: 5
Thread 1: 8
Thread 2: 6
Thread 3: 6
Thread 3: 7
Thread 1: 9
Thread 2: 7
Thread 3: 8
Thread 1: 10
Thread 3: 9
Thread 3: 10
Thread 2: 8
Thread 2: 9
Thread 2: 10

Wieso zählt da nun jeder Thread für sich selbst? der Counter sollte doch eigentlich synchronisiert sein :-/

Für einen Denkanstoß wäre ich sehr dankbar :)

Grüße,

Lorus
 

Wildcard

Top Contributor
Jeder Thread hat seinen eigenen Counter, die haben nicht das geringste miteinander zu tun.
 
L

Lorus

Gast
Wie kann man es denn dann hinbekommen, das sie einen gemeinsamen Counter benutzen?
Ich dachte für sowas ist das synchronized gemacht.

Hast du irgend einen Denkanstoß für mich, wie ich das realisieren könnte?


Vielen Dank,

Lorus
 

musiKk

Top Contributor
Dafür ist synchronized nicht. Wenn du verschiedene Instanzen eines Objekts separat behandelst, gibt es nichts zu synchronisieren. Synchronisiert werden muss dann, wenn mehrere Threads auf das selbe Objekt zugreifen.

Du könntest einen statischen Counter benutzen oder ein einziges Counter-Objekt initialisieren und allen drei Threads (z. B. über den Konstruktor) zuweisen.
 
G

Guest

Gast
musiKk hat gesagt.:
Dafür ist synchronized nicht. Wenn du verschiedene Instanzen eines Objekts separat behandelst, gibt es nichts zu synchronisieren. Synchronisiert werden muss dann, wenn mehrere Threads auf das selbe Objekt zugreifen.

Du könntest einen statischen Counter benutzen oder ein einziges Counter-Objekt initialisieren und allen drei Threads (z. B. über den Konstruktor) zuweisen.

Ok, das habe ich nunmal versucht ... hier der neue Code:

Code:
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */

package http;

/**
 *
 * @author clorentz
 */
class Counter {
    int Counter=0;
        
    public synchronized int getCounterValue() {
        return Counter;
    }
        
    public synchronized void incrementCounter() {
        Counter++;
    }
}

class TextThread extends Thread {
    String text;
    Counter count;

    public TextThread(String text, Counter count) {
        this.count = count;
        this.text = text;
    }

    public void run() {
        
        while(count.getCounterValue() < 10) {
            count.incrementCounter();  
            try {
                sleep((int)(Math.random()*1000));
            }
            catch(InterruptedException e) { 
            }
            System.out.println(text + ": " + count.getCounterValue()); 
        }
    }
} 

class TextThreadDemo {

    public static void main(String args[]) {
        TextThread t1, t2, t3;
        Counter count = new Counter();
        t1= new TextThread("Thread 1",count);
        t2 = new TextThread("Thread 2",count);
        t3 = new TextThread("Thread 3",count);
        t1.start();
        t2.start();
        t3.start();
    }
}

Nun bekomm ich aber folgendes Ergebnis:

Thread 3: 3
Thread 1: 4
Thread 3: 5
Thread 2: 6
Thread 3: 7
Thread 1: 8
Thread 2: 9
Thread 3: 10
Thread 1: 10
Thread 2: 10

Nun greifen sie wohl allerdings zeitgleich auf den Counter zu ... und so soll es ja nicht sein .... jede Ausgabe des Counters-Standes soll ja nur genau einmal erfolgen.
 

Ark

Top Contributor
Ein synchronized in der Methodendeklaration bewirkt das gleiche, als würde man den gesamten Rumpf dieser Methode von einem synchronized(this) umschließen. Bei this handelt es sich allerdings für jedes Objekt um ein anderes, weshalb ein synchronized(this) praktisch wirkungslos ist.

Nimm das synchronized doch mal aus den Methodendeklarationen raus und packe dafür die Rümpfe jeweils in einen synchronized(Counter.class)-Block:
Code:
public int getCounterValue() {
    synchronized(Counter.class){
        return Counter;
    }
}
usw. Das, denke ich, sollte dann funktionieren.

Ark
 

Landei

Top Contributor
Sollte so gehen wie Ark schreibt. Eine Alternative wäre java.util.concurrent.atomic.AtomicReference, das ist sozusagen ein synchronisierter Wrapper um die Variable.
 
G

Guest

Gast
Hab gerade ein ähnliches Problem, aber das mit
Code:
Counter.class
funktioniert auch nicht. Habs ausprobiert. Es sieht zuerst so aus, als ob
der Counter synchronisiert hochgezählt wird, aber wenn die Threads immer genauso lang
schlafen, dann kommt bei mir

Thread 3: 3
Thread 1: 3
Thread 2: 3
Thread 1: 6
Thread 2: 6
Thread 3: 6
Thread 2: 9
Thread 3: 9
Thread 1: 9
Thread 2: 10
 

tfa

Top Contributor
Landei hat gesagt.:
Sollte so gehen wie Ark schreibt.
Nein. Im zweiten Beispiel gibt es doch nur noch eine Counter-Variable. Dann ist es völlig egal, ob hier auf die Variable oder die Klasse synchronisiert wird. Da kommt das selbe raus.

Wenn wirklich das ausgegeben werden soll, was oben gefordert wird, muss das Inkrementieren und Holen des Wertes eine atomare Transaktion sein, z.B.

Code:
while(count.getCounterValue() < 10) { 
     synchronized (count) {
          count.incrementCounter();
          System.out.println(text + ": " + count.getCounterValue());	
     }
     try { 
          sleep((int)(Math.random()*1000)); 
     } 
     catch(InterruptedException e) { }
}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
berserkerdq2 Wo finde ich in der Java Api die Notation zu Threads bezüglich Synchronized? Java Basics - Anfänger-Themen 14
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
X Threads Zwei Threads, aber doppelte Ausgabe verhindern (synchronized) Java Basics - Anfänger-Themen 54
Z Threads Threads - Zugriff auf Ressourcen ohne(Lock, Synchronized) Java Basics - Anfänger-Themen 2
B synchronized threads Java Basics - Anfänger-Themen 17
B warum schließt synchronized andere threads nicht aus? Java Basics - Anfänger-Themen 7
I Synchronized Threads Java Basics - Anfänger-Themen 4
R Problem: Threads Synchronized machen Java Basics - Anfänger-Themen 5
M OOP Synchronized Methoden, zugriff aus Threads Java Basics - Anfänger-Themen 4
X Threads und synchronized - Verständnisproblem Java Basics - Anfänger-Themen 3
M Kleines Problem mit Threads (synchronized) Java Basics - Anfänger-Themen 3
S bin zu blöd für threads - wait, notify, synchronized Java Basics - Anfänger-Themen 11
S Threads: synchronized mach nicht was es soll? Java Basics - Anfänger-Themen 6
A Problem mit Threads und synchronized Java Basics - Anfänger-Themen 3
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
C Threads und Swing Java Basics - Anfänger-Themen 9
B Monitor als Schranke von Threads Java Basics - Anfänger-Themen 20
W Threads Alphabet Java Basics - Anfänger-Themen 20
H Threads Anfänger Java Basics - Anfänger-Themen 17
1 Threads parallel laufen Java Basics - Anfänger-Themen 11
B Threads Problem mit mehreren Threads Java Basics - Anfänger-Themen 38
M Threads Java Basics - Anfänger-Themen 12
L Threads Synchronisierung zwischen threads Java Basics - Anfänger-Themen 4
M Threads Java Basics - Anfänger-Themen 2
A Threads Java Basics - Anfänger-Themen 9
A Threads Java Basics - Anfänger-Themen 13
A Threads und .join Java Basics - Anfänger-Themen 14
W Threads starten Java Basics - Anfänger-Themen 2
J Wieviele threads? Java Basics - Anfänger-Themen 9
J Problem bei seriellem Start von Threads Java Basics - Anfänger-Themen 11
O Threads Java Basics - Anfänger-Themen 2
L Buchungssystem und Threads Java Basics - Anfänger-Themen 2
O Threads - Synchronize(), join(), wait(), notify(), yield() Java Basics - Anfänger-Themen 6
L Klassen NFC Reader und JavaFx Problem -> threads? Java Basics - Anfänger-Themen 2
A Kommunikation zwischen nebenläufigen Threads Java Basics - Anfänger-Themen 4
S Gemeinsame Ressource und Mehrfachinstanziierung von Threads Java Basics - Anfänger-Themen 16
S Verklemmung Threads Java Basics - Anfänger-Themen 11
B Threads 2 Threads gleichzeitig laufen lassen Java Basics - Anfänger-Themen 1
M Threads Threads laufen sequenziell, statt gleichzeitig. Java Basics - Anfänger-Themen 9
M Threads run Methode Java Basics - Anfänger-Themen 4
javajoshi mehrere Threads: Methoden zentral unterbringen Java Basics - Anfänger-Themen 8
javajoshi Problem mit zwei Threads und Arrays (Runnable) Java Basics - Anfänger-Themen 12
L Threads Mit Threads JLabel ändern! Java Basics - Anfänger-Themen 2
K Matrixen berechnen nach Worker Master Paradigma mit Threads Java Basics - Anfänger-Themen 4
S Kleine Frage zu Threads Java Basics - Anfänger-Themen 3
M Mit 2 Threads eine Zahl hochzählen Java Basics - Anfänger-Themen 13
T Threads Synchronisieren Java Basics - Anfänger-Themen 6
D Frage Threads Java Basics - Anfänger-Themen 6
Z Threads Executor Framework - Aufgabe auf n Threads aufteilen Java Basics - Anfänger-Themen 10
kilopack15 Verständnisfrage zur Verwendung von notify() bei Threads Java Basics - Anfänger-Themen 2
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
H Threads funktionieren nicht Java Basics - Anfänger-Themen 4
J Aufgabe(Threads) richtig verstanden/implementiert Java Basics - Anfänger-Themen 27
R Threads aufeinander warten lassen? Java Basics - Anfänger-Themen 10
T Threads Durch threads gestartete Prozesse killen Java Basics - Anfänger-Themen 2
J Threads Java Basics - Anfänger-Themen 38
D Alte Klausuraufgabe Threads Java Basics - Anfänger-Themen 10
A Threads Threads bestimmte Aufgaben zuweisen... Java Basics - Anfänger-Themen 3
R Threads in JavaFX Java Basics - Anfänger-Themen 3
E Threads Doppelte Threads beenden Java Basics - Anfänger-Themen 4
F Sicheres Zurückmelden aus Threads Java Basics - Anfänger-Themen 0
G Threads zum Thema Threads??? null Ahnung Java Basics - Anfänger-Themen 4
Q Threads Threads in Swing Anwendungen Java Basics - Anfänger-Themen 5
J ConcurrentCalculation Multi Threads in Java Java Basics - Anfänger-Themen 3
P Threads Trotz Threads wird nur 1 Prozessorkern ausgelastet Java Basics - Anfänger-Themen 7
M "restartable" threads Java Basics - Anfänger-Themen 11
M Threads - summieren Java Basics - Anfänger-Themen 13
W Klassen Variable einer anderen Klasse ändern (Threads) Java Basics - Anfänger-Themen 3
E Threads - Programm analysieren Java Basics - Anfänger-Themen 2
E join() bei zwei Threads Java Basics - Anfänger-Themen 2
T Threads Threads richtig synchronisieren Java Basics - Anfänger-Themen 3
D [Concurrency/Threads] Code Umsetzung Schriftlich Java Basics - Anfänger-Themen 2
D Threads Java Basics - Anfänger-Themen 4
M Threads nio Dateien kopieren, Threads und Gui Java Basics - Anfänger-Themen 0
N Verweise auf Variablen in verschiedenen Threads Java Basics - Anfänger-Themen 4
T Java-Threads Java Basics - Anfänger-Themen 0
G Moving Objects with Threads (implements Runnable) Java Basics - Anfänger-Themen 1
F Threads funktionieren auf JPanel nicht Java Basics - Anfänger-Themen 1
M Problem mit Threads Java Basics - Anfänger-Themen 11
M Threads - wo gehören sie hin? Java Basics - Anfänger-Themen 3
S 2D-Spiel mit Threads... Java Basics - Anfänger-Themen 3
J Threads Java Basics - Anfänger-Themen 3
F ExecutorService und offene Threads Java Basics - Anfänger-Themen 3
P Threads Threads nicht nebenläufig Java Basics - Anfänger-Themen 7
M Threads nicht nebenleblaufig Java Basics - Anfänger-Themen 2
B Threads parallel zur main Java Basics - Anfänger-Themen 3
M Threads Java Basics - Anfänger-Themen 2
M Threads, zwei methoden gleichzeitig laufen lassen Java Basics - Anfänger-Themen 4
M Threads und Methodenübergreifender Variablezugriff Java Basics - Anfänger-Themen 2
J Wie handle ich Threads am besten? Java Basics - Anfänger-Themen 2
H Threads Java Basics - Anfänger-Themen 10
E Mehrmaliges Ausführen eines Threads Java Basics - Anfänger-Themen 5
E Threads Verständnisfrage bzgl. Threads und Sleep Java Basics - Anfänger-Themen 2
T Alle Threads .notify() Java Basics - Anfänger-Themen 13
R Threads Verständnisschwierigkeit Java Basics - Anfänger-Themen 2
J Können mehere Threads parallel eine Datei lesen? Java Basics - Anfänger-Themen 4
G Methoden in Threads wandeln Java Basics - Anfänger-Themen 7
H Threads Java Basics - Anfänger-Themen 17
F Java Concurrency - Threads Java Basics - Anfänger-Themen 4
V Threads Threads synchronisieren Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben