Thread-Frage

Status
Nicht offen für weitere Antworten.

Schachmann

Mitglied
Hallo,

folgendes Problem: Was genau passiert durch das markierte n.wait(); geht an der Stelle der main-Thread schlafen oder der n-Thread? Ich hab schon einiges :rtfm: aber irgendwie sind die Erklärungen alle nur wischi-waschi.
Denn nach meiner momentanen Kenntnislage könnte es doch sein, das nach n.start(); der Scheduler tatsächlich den n.thread laufen lässt, dieser arbeitet die synchronisierte Schleife ab und macht dann das notify(). Aber wo zielt das notify() dann hin? Da der main-Thread ja noch nicht weiter als bis zu dem n.start() gelaufen ist, war er ja noch nicht bei dem n.wait(); Dieses würde der main-Thread dann ja erst abarbeiten, wenn das notify() schon vorbei ist?

Wäre echt toll, wenn jemand eine Erklärung hätte, die es in meinem Hirn klicken lässt...

Gruß,
Ralf


Java:
package threadwait;

public class Main {
    public static void main(String[] args) {
        ThreadNotify n=new ThreadNotify();
        n.start();
        
        synchronized(n) {
            try {
                n.wait();                            // Hier liegt der Hund begraben
            } catch(InterruptedException e) { }
        }
        System.out.println("Der letzte Eintrag ist: "+n.last);       
    }
}


class ThreadNotify extends Thread {
    int last;

    public void run() {
        synchronized(this) {
            for(int i=0; i<100;i++) {
                last=i;
            }
            
            notify();
        }
    }
}
 

Leroy42

Top Contributor
Aber wo zielt das notify() dann hin? Da der main-Thread ja noch nicht weiter als bis zu dem n.start() gelaufen ist, war er ja noch nicht bei dem n.wait();

Falsch!

Das n.start() startet den Thread aber der momentan laufende Thread wird dennoch
weiterabgearbeitet.

Erst nach Erreichen des n.wait() wird der Thread angehalten und durch
das notify() im n-Thread wieder weiter laufen gelassen.
 
S

SlaterB

Gast
am Ende jedes Threads wird übrigens sowieso notifyAll() aufgerufen,

es gibt auch Thread.join(), ganz ohne synchronized-Block + try/catch,
womit ein anderer Thread explitzit auf das Ende des Threads wartet und beliebige notify() zwischendurch ignoriert
 

Leroy42

Top Contributor
Nochwas zur Klarstellung:

das nach n.start(); der Scheduler tatsächlich den n.thread laufen lässt, dieser arbeitet die synchronisierte Schleife ab und macht dann das notify()[/code]

Richtig! Aber der main-Thread wartet nicht sondern läuft quasi-parallel
nach Aufruf des zweiten Threads (n.start()) weiter!
 

Schachmann

Mitglied
Nochwas zur Klarstellung:
Richtig! Aber der main-Thread wartet nicht sondern läuft quasi-parallel
nach Aufruf des zweiten Threads (n.start()) weiter!

Seh ich nicht so. Die sind ja beide am selben Objekt synchronisiert. Wenn die Schleife also mal läuft, müsste der main-Thread blockiert werden, da ja der n-Thread den Lock hat. Oder liege ich da schief?

Gruß,
Ralf
 

Leroy42

Top Contributor
Uppss! Hast recht!

(Warum ist das "Ich schäme mich" - Smiley nicht mehr da?) :oops:

Da bin ich auch überfragt und warte auf SlaterB's Antwort! :bahnhof:

:D
 

Schachmann

Mitglied
am Ende jedes Threads wird übrigens sowieso notifyAll() aufgerufen,

es gibt auch Thread.join(), ganz ohne synchronized-Block + try/catch,
womit ein anderer Thread explitzit auf das Ende des Threads wartet und beliebige notify() zwischendurch ignoriert

Das mit notifyAll() stimmt, man kann also das notify() getrost weglassen. Aber es bleibt immer noch meine Frage: Wenn nach dem n.start(); der Scheduler entscheidet den n-Thread wirklich laufen zu lassen, kommt dieser in einen synchronisierten Block. In dem Moment wird also der main-Thread nicht weiterkommen, da ja der n-Thread den Lock hat, dieser läuft also bis zum notify(); und stirbt dann, und erst dann läuft ja der main-Thread wieder und erreicht das n.wait(); Dann kommt aber niemals, niemals, niemals mehr ein notify();

Bin für jeden Tipp dankbar,
Gruß,
Ralf
 

Leroy42

Top Contributor
und erst dann läuft ja der main-Thread wieder und erreicht das n.wait(); Dann kommt aber niemals, niemals, niemals mehr ein notify();

Vielleich wird dem wait() schon dann genüge getan, wenn das notify()
vorher aufgerufen wurde.

Aber das ist jetzt nur meine Vermutung! :bahnhof:

Ich bin jetzt auch neugierig und warte auf SlaterB's (oder
andere) Antwort/en.
 
S

SlaterB

Gast
@Schachmann
die Situation kann so eintreten, ob erst der main-Thread das wait() oder der n-Thread sein Ende erreicht, ist zufallsabhängig,

und ja, das wait() kann dann ewig warten,

was ist aber die Frage?
du könntest im main-Thread abfragen, ob der Thread schon zu Ende ist,
oder wie gesagt join() verwenden, das ist auch sofort zu Ende, wenn der Thread nicht mehr lebt

Java:
    public final synchronized void join(long millis) 
    throws InterruptedException {
	long base = System.currentTimeMillis();
	long now = 0;

	if (millis < 0) {
            throw new IllegalArgumentException("timeout value is negative");
	}

	if (millis == 0) {
	    while (isAlive()) {
		wait(0);
	    }
	} else {
	    while (isAlive()) {
		long delay = millis - now;
		if (delay <= 0) {
		    break;
		}
		wait(delay);
		now = System.currentTimeMillis() - base;
	    }
	}
    }
 

Schachmann

Mitglied
Naja, das Problem liegt darin, dass mein Dozent behaupt hat, das der Compiler ja den kompletten Sourcecode sieht und schon irgendwie dafür sorgt, dass das wait() vor dem notify() ausgeführt wird. Aber wie konnte er mir auch nicht sagen.
Und ich glaube halt nicht, das der Compiler sich darum kümmert, sondern das es wirklich zufällig ist, welcher Thread zuerst läuft. Im Buch "Das große SCJP-Trainingsbuch" von Ina Brenner wird aber auf Seite 398 ff. auch so getan, als ob 100 %ig gewährleistet ist, dass der main-Thread wartet und der n-Thread dann notify() aufruft.
 

Leroy42

Top Contributor
Naja, das Problem liegt darin, dass mein Dozent behaupt hat, das der Compiler ja den kompletten Sourcecode sieht und schon irgendwie dafür sorgt, dass das wait() vor dem notify() ausgeführt wird. Aber wie konnte er mir auch nicht sagen.
:shock:

Wovon träumt dein Dozent denn sonstso nachts?
:lol:
Und ich glaube halt nicht, das der Compiler sich darum kümmert, sondern das es wirklich zufällig ist, welcher Thread zuerst läuft.

Stimmt! Das sehe ich genauso! Gebe demnach also
SlaterB's Erklärung Recht!
 
G

Gast2

Gast
Naja, das Problem liegt darin, dass mein Dozent behaupt hat, das der Compiler ja den kompletten Sourcecode sieht und schon irgendwie dafür sorgt, dass das wait() vor dem notify() ausgeführt wird. Aber wie konnte er mir auch nicht sagen.
:D ... schon irgendwie ... ist ja klasse ... wo die immer solche Dozenten ausgraben ... ich finde es schade das in D (?) immer gemecket wird as Informatiker fehlen - bei solchen Dozent ist mir das klar ;( ... gut - sichert meinen Arbeitsplatz

Und ich glaube halt nicht, das der Compiler sich darum kümmert, sondern das es wirklich zufällig ist, welcher Thread zuerst läuft.
na die Wahrscheinlichkeit ist sehr hoch das der Hauptthread zuerst in das wait() stolpert ... der Thread läuft ja bereits ... sollte auf einem Singlecore aber auch zu 100% nicht stimmen !

ab einem Dualcore kann der Hauptthread durch ein Interrupt beendet werden und der Kern macht vor dem wait() einen Kontextwechsel ... der zweite Kern wurde vom BS mit der Abarbeitung des Nebenthread beauftragt und kann auch beginnen (nur Kern 1 ist im Interrupt) ... dann kann es passieren das der NT fertig wird, bevor der HT die Arbeit wieder aufnimmt und in das wait() stolpert ... Nachtrag ... der Hauptthread kann auch ohne Interrupt einem Kontextwechsel folgen, weil einfach die Zeit für diesen Thread abgelaufen ist :bahnhof:

in einem Singlecore hängt es vom BS ab ob der Hauptthread nach dem Interrupt wieder abgearbeitet wird oder ein anderer Thread aus der Schlange geholt ... sollte letzteres der Fall sein, wird erst der Nebenthread abgearbeitet bevor der Hauptthread wieder an der Reihe ist ... von möglichen Kontextwechseln in der CPU mal ganz abgesehen
 
Zuletzt bearbeitet von einem Moderator:

Leroy42

Top Contributor
ab einem Quadcore kann der Hauptthread durch ein Interrupt beendet werden und der Kern macht vor dem wait() einen Kontextwechsel ... der zweite Kern wurde vom BS mit der Abarbeitung des Nebenthread beauftragt ...

Also Ergebnis vons Janze:

Brave Programmierer coden sowas nicht! :pueh:

(dann kommen sie auch bestimmt in den Himmel! :D)
 

Schachmann

Mitglied
Naja, also wegen mir musst Du Dich wirklich nicht schämen!

Ich danke auf jeden Fall mal allen, die sich über mein kleines Problem Gedanken gemacht haben. Ich sehe es jetzt bis zum Gegenbeweis mal so, dass es tatsächlich ziemlich wahrscheinlich ist, dass das wait(); zuerst läuft, aber eben nicht 100 % sicher.

Danke nochmals,
beste Grüße,
Ralf
 
G

Gast2

Gast
Brave Programmierer coden sowas nicht! :pueh:

ich weis sowieso nicht wieso alle Welt immer mit Thread-Prioritäten spielen müssen ... kann das BS viel besser ... gut ... es gibt ein paar Ausnahmen wo es Sinn macht einen Thread auf einen Kern festzunageln (aber mehr als zwei fallen mir spontan nicht ein) ... aber an den Prioritäten zu spielen ist sinnlos
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Threads Thread sleep() Method einfache Frage Java Basics - Anfänger-Themen 8
ralfb1105 Frage zu Thread Synchronisation mit wait() und notify() Java Basics - Anfänger-Themen 3
L Thread-Frage Java Basics - Anfänger-Themen 2
S Thread.sleep () - Frage Java Basics - Anfänger-Themen 16
O Thread Frage Java Basics - Anfänger-Themen 6
A Frage zu Datenzugriff bei new Thread(new Runnable) Java Basics - Anfänger-Themen 8
M Frage zur Methode Thread.sleep() Java Basics - Anfänger-Themen 6
G SWT Thread Verständniss frage Java Basics - Anfänger-Themen 6
G Frage zur Thread-Programmierung Java Basics - Anfänger-Themen 5
G Thread Erzeuger-Verbraucher-Frage Java Basics - Anfänger-Themen 4
P Thread Frage Java Basics - Anfänger-Themen 7
R Frage zu Thread und aufruf von Methoden Java Basics - Anfänger-Themen 2
R Thread(Group)-Frage Java Basics - Anfänger-Themen 4
R Thread-Frage Java Basics - Anfänger-Themen 8
Leyla Thread isInterrupt Java Basics - Anfänger-Themen 18
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
A Thread XML-Dateien zusammenfügen Java Basics - Anfänger-Themen 11
F influxdb Upload in eigenem Thread Java Basics - Anfänger-Themen 2
frager2345 Thread - Methoden synchronized deklarieren Java Basics - Anfänger-Themen 10
berserkerdq2 Größter unterschied von extends thread und implements runnable? Java Basics - Anfänger-Themen 2
T Thread beenden aus zweiter Klasse Java Basics - Anfänger-Themen 4
A Thread - Synchronized Java Basics - Anfänger-Themen 10
A Thread Producer - Consumer Java Basics - Anfänger-Themen 1
A Thread-Semhapore Java Basics - Anfänger-Themen 0
A Thread Exchanger Java Basics - Anfänger-Themen 22
A Thread-Cyclicbarrier Java Basics - Anfänger-Themen 4
B In einem Thread Endlosschleife beenden Java Basics - Anfänger-Themen 19
A Thread-Verklemmung Java Basics - Anfänger-Themen 10
A Thread-Schreibe-Lese-Problem Java Basics - Anfänger-Themen 4
A Thread find number Java Basics - Anfänger-Themen 8
F Thread.sleep() Java Basics - Anfänger-Themen 5
F Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 11 at main.main(main.java:11) Java Basics - Anfänger-Themen 2
A Thread Java Basics - Anfänger-Themen 3
M Exception in thread "main" java.util.NoSuchElementException Java Basics - Anfänger-Themen 2
A Thread Java Basics - Anfänger-Themen 8
B Compiler-Fehler Fehlermeldung Exception in thread, falsche Eingabewert Java Basics - Anfänger-Themen 2
M Thread-Zustände Java Basics - Anfänger-Themen 6
CptK For-Schleife in Thread nach jedem Durchlauf pausieren Java Basics - Anfänger-Themen 35
S Kriege Fehler "Exception in thread" beim Benutzen von SubStrings. Java Basics - Anfänger-Themen 2
B Endlosschleife Thread sauber beenden Java Basics - Anfänger-Themen 19
D Java Thread wartet nur ein mal Java Basics - Anfänger-Themen 1
D Java Thread wartet nur ein mal Java Basics - Anfänger-Themen 0
O Exception in thread "main" java.lang.ArithmeticException: / by zero Java Basics - Anfänger-Themen 4
C Thread und TimerTask, Verstädnisproblem Java Basics - Anfänger-Themen 10
amgadalghabra Sorting Thread Launcher Java Basics - Anfänger-Themen 3
B Exception in thread "AWT-EventQueue-0" java.util.ConcurrentModificationException Java Basics - Anfänger-Themen 8
A Thread Java Basics - Anfänger-Themen 4
A Thread Java Basics - Anfänger-Themen 1
A Thread Java Basics - Anfänger-Themen 0
R Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException Java Basics - Anfänger-Themen 5
S Compiler-Fehler Exception in thread "main" java.lang.Error: Unresolved compilation problem: Java Basics - Anfänger-Themen 6
L Liste in anderem Thread laden Java Basics - Anfänger-Themen 1
B Thread / Prozess stoppen? Java Basics - Anfänger-Themen 22
I Compiler-Fehler Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 5 Java Basics - Anfänger-Themen 3
W Thread Aufgabe - Vorgehensweise Java Basics - Anfänger-Themen 8
L Liste in anderem Thread laden Java Basics - Anfänger-Themen 0
J Threads PrograssBar update während thread Java Basics - Anfänger-Themen 13
D Compiler-Fehler Wert auf Datenbank übertragen und Sleep Thread Java Basics - Anfänger-Themen 3
Spencer Reid JavaFX Memory Thread.sleep Java Basics - Anfänger-Themen 1
S Thread.sleep mit JProgressBar Java Basics - Anfänger-Themen 1
R Exception in thread "main" java.lang.NullPointerException Java Basics - Anfänger-Themen 10
J JavaFX -> SocketIO -> Thread -> Update Label Java Basics - Anfänger-Themen 13
J Thread Handling Java Basics - Anfänger-Themen 9
A Problem mit Thread.sleep Java Basics - Anfänger-Themen 4
C Thread in Methode + raus aus der Schleife Java Basics - Anfänger-Themen 10
E Threads Thread in While-Schleife nur einmal starten Java Basics - Anfänger-Themen 2
F Daten von Thread an den aufrufenden zurückgeben Java Basics - Anfänger-Themen 22
C Compiler-Fehler Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 2 Java Basics - Anfänger-Themen 3
B Thread Problem Java Basics - Anfänger-Themen 7
N KeyListener in Thread Java Basics - Anfänger-Themen 0
M Thread.sleep() Funktion Java Basics - Anfänger-Themen 1
W JLabel in Main aus Thread verändern. Java Basics - Anfänger-Themen 4
D Ausgeben welcher Thread gerade Arbeitet Java Basics - Anfänger-Themen 8
N Threads Thread-Fehler Java Basics - Anfänger-Themen 2
F Thread um Uhrzeit ausführen Java Basics - Anfänger-Themen 5
F Get/Post als eigener Thread mit Rückgabe Java Basics - Anfänger-Themen 5
J Exception in thread "main" Java Basics - Anfänger-Themen 1
F Thread der auf eine Queue wartet, sicher beenden Java Basics - Anfänger-Themen 4
B Animation mit Thread(s) Java Basics - Anfänger-Themen 23
I Thread.sleep (1000); Java Basics - Anfänger-Themen 1
M Threads Jede Klasse einem Thread zuweisen Java Basics - Anfänger-Themen 7
J Java Thread cancel() und wiederbeleben Java Basics - Anfänger-Themen 4
J BouncingBalls 1 Thread Java Basics - Anfänger-Themen 3
L Fehler: Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException Java Basics - Anfänger-Themen 4
J Timer oder Thread programmieren ? Java Basics - Anfänger-Themen 10
fLooojava Laufender Thread | Boolean ändern Java Basics - Anfänger-Themen 9
T Thread Pool mit Work Stealing Java Basics - Anfänger-Themen 1
R Java Thread Java Basics - Anfänger-Themen 10
J Welche Methoden laufen im neuen thread ?? Java Basics - Anfänger-Themen 9
S Java memory fehler: Exception in thread "AWT-EventQueue-0" java.lang.OutOfMemoryError: Java heap spa Java Basics - Anfänger-Themen 5
K Thread - Methoden in die run Methode Schreiben Java Basics - Anfänger-Themen 5
N Threads Exception in thread "main"... Feher bei dem Versuch ein Radius zu berechnen Java Basics - Anfänger-Themen 4
A Code läuft nicht, Fehlermeldung Exception in thread "main" java.lang.Error: Unresolved compilation " Java Basics - Anfänger-Themen 11
V Threads Exception in Thread behandeln Java Basics - Anfänger-Themen 3
S Methoden Multi-Thread und Methoden Objects. Java Basics - Anfänger-Themen 1
J Thread erstellen (BlueJ Projekt) Java Basics - Anfänger-Themen 3
P Exception in thread "main" java.lang.NoClassDefFoundError: Java Basics - Anfänger-Themen 1
F Threads Variable aus einem Thread in main Methode? Java Basics - Anfänger-Themen 9
K Exception in thread "main" Java Basics - Anfänger-Themen 7
E Was ist ein idle-thread? Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben