Thread-Debugging, wie?

Status
Nicht offen für weitere Antworten.

Wolfram

Mitglied
Multithreading ist nicht für Menschen gemacht, glaub ich ... das ist ja die GOTO-Problematik hoch 10. Echt eklig.

Ich wüsste gerne, was für Möglichkeiten es gibt, Java-Threads zu debuggen? Ich stelle mir z.B. ein Tool vor, das Start und Beenden, wait() und notify() hübsch grafisch darstellt, woran man dann sehen könnte, dass ein Thread gar nicht gestartet wurde, oder ein Thread auf ein notify() wartet, das nie kommt, und dergleichen mehr.

Hintergrund: Momentan arbeite ich mit System.out.println und logge mit, wann was startet/terminiert, aber das hat mein aktuelles Problem nicht abgefangen, dass ich versehentlich run() statt start() aufgerufen habe.

Gibt's da was interessantes? Oder wie debuggt Ihr Eure Threads?
 

byte

Top Contributor
Wenn möglich arbeite ich gar nicht mit wait() / notify() ... Ansonsten würde ich Dir raten, falls Du Java 5 verwendest, Dir mal das Concurrency Framework anzugucken. Das bietet eine recht gute Abstraktion gegenüber Threads und vereinfacht die Handhabung ungemein. Für Concurrency in Swing ist der SwingWorker noch interessant. Ansonsten empfehle ich einen Debugger zu benutzen, wie ihn z.B. Eclipse bietet. Statt System.out würde ich dann noch einen Logger wie log4j einsetzen. Richtig konfiguriert schreibt er Dir direkt mit in die Ausgabe, aus welchem Thread die Message kommt.
 

Marco13

Top Contributor
Naja - der Debugger, der z.B. bei Eclipse dabei ist, erlaubt es ja, z.B. auf "Pause" zu stellen, und nachzusehen, was die Threads so gerade machen....
 

fehlerfinder

Bekanntes Mitglied
log4j - wie der Kollege schon sagte. Gegen run() statt start() hilft nur Doku-Studium ;-)

Frameworks zur Abstraktion sind bestimmt schön und gut (auch wenn ich mich - ehrlich gesagt - damit noch nicht beschäftigt habe), aber man sollte auf alle Fälle die Grundlagen der Thread-Programmierung, -Behandlung, -Anwendung (was-auch-immer) VERSTANDEN haben - so richtig. Dazu empfehle ich die einschlägige Doku im Netz, sei's nun die "Java-Insel" aus dem Galileo-Verlag oder das Sun-Tutorial. Und dann schreibst du jede Menge KLEINE Klassen, die sich einen speziellen Teil der Thread-Bearbeitung vornehmen und darüber Protokoll führen - z.B. per log4j oder aber auch mit vernünftig parametrierten System.out-Statements (aber bevor du die vernünftig parametriert hast, hast du dich auch in log4j eingearbeitet ;-) )

Danach(!) passiert dir dann sowas wie run/start nicht mehr.

Für die Erkennung von Dead-Locks, die z.B. bei unvoreingenommener Verwendung von synchronized-Blöcken auftreten können, gibt es dann Samurai, ein grafisches Debugging-Tool für die Auswertung von Thread-Dumps. Einen solchen Dump erstellst du unter Linux per "kill -3 <pid>", wobei <pid> natürlich die process-id deines Java-Programms ist. Wie das unter Windows geht, kann ich leider nicht sagen.
 

Wolfram

Mitglied
Danke für die Antworten so weit!

Kurz zur Klärung, weil Ihr alle drauf eingegangen seid, dass ich System.out.println geschrieben habe, bezog sich auf die Debugging-Methode - ich wollte nicht printf()-Debugging schreiben :) Der Applikation-Server lenkt stdout bereits auf log4j um, und erspart mir das somit. Auch arbeite ich nicht direkt mit den Monitor-Funktionen, da wird man ja komplett wahnsinnig. Ich bin heilfroh, dass es das Concurrent-Framework gibt. Von einem Debugger würde ich aber nicht mehr erwarten, als dass ich wait() und notify() angezeigt bekomme.

Was ich soweit gelernt habe,

* jstack zeigt einem auf der Konsole Stack-Traces aller Threads an, das kann aber für einen Application-Server recht unübersichtlich werden,

* der IDE-Debugger von NetBeans kann ebenfalls eine Liste aller threads und deren Zustand anzeigen, allerdings ist die Bedienung etwas schwierig,

* *ganz wichtig* man sollte in so einem Fall "seinen" Threads vernünftige Namen verpassen, Thread-342 ist etwas nichtssagend, also zu Anfang von run() einfach einmal this.setName("MeinThread-"+this.getName()) machen, damit man schnell überblicken kann, ob auch alle da sind etc. :)

Grüße,
Wolfram
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
B Threads Thread sleep() Method einfache Frage Java Basics - Anfänger-Themen 8
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
ralfb1105 Frage zu Thread Synchronisation mit wait() und notify() Java Basics - Anfänger-Themen 3
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
L Thread-Frage Java Basics - Anfänger-Themen 2
E Was ist ein idle-thread? Java Basics - Anfänger-Themen 1
D Exception in thread "AWT-EventQueue-0" Java Basics - Anfänger-Themen 8
J Threads Prozess in Thread auslagern Java Basics - Anfänger-Themen 2
G Thread mehrmals starten und schliessen Java Basics - Anfänger-Themen 6
F Thread Koordination (Vorteile/Nachteile) Java Basics - Anfänger-Themen 0
O Thread aus dem Thread stoppen Java Basics - Anfänger-Themen 6
O Swingworker/Thread Java Basics - Anfänger-Themen 3
R Focus auf JPanel im Thread Java Basics - Anfänger-Themen 9
S musik in eigenem thread Java Basics - Anfänger-Themen 2
A Klasse,Vererbung,Interface,Singleton,Thread Java Basics - Anfänger-Themen 5
IngoF GUI mit Thread Daten austauschen. Java Basics - Anfänger-Themen 6
L Compiler-Fehler Exception in thread "main" java.lang.NullPointerException Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben