Thread-Neustart - Nur wie?

Status
Nicht offen für weitere Antworten.
P

Peetman

Gast
Hallo,

ich habe von log4j abgeleitet eine eigene kleine Bibliothek geschrieben, die zum Loggen verwendet werden soll.
Nun sollen die Logfiles bei erreichen bestimmter Bedingungen rotiert werden. Das klappt soweit auch.

Damit große Logfiles während ihres Rotationsvorganges nicht das Logging aufhalten, habe ich die Rotation in einen Thread ausgelagert. Auch das funktioniert grundsätzlich.

Nun zum eigentlichen Problem:

Wenn der besagte Thread in der Methode run() eine Endlosschleife fährt, klappt alles, bis auf das Beenden des Programmes, *solange* ich nicht im *Programm* etwas aufrufe, dass dafür sorgt, dass der Thread gestoppt wird.
Das ist soweit normal, aber für meine Zwecke unschön; Die Logging-Bibliothek soll auch von Vollpfosten benutzt werden können, die keine Ahnung von Threads & Co. haben, und nicht dazu zu bewegen sind, den Logger "zu stoppen". (Die Argumentation: dann beendet sich ihr Programm eben einfach nicht, weil der Thread noch läuft und läuft und läuft, zieht nicht; die benutzen dann einfach nicht *diesen* Logger, sondern machen anderen Mist; Und das Ziel soll eigentlich sein, dass die diesen Logger benutzen, damit anderes drum herum einfacher wird).

Konsequenz: run() nicht endlos, und jedes Mal, wenn ich etwas in die Queue packe, um es aus dem Weg zu räumen (also im rollOver()), den Thread aus meiner Bibliothek heraus neu starten.

Und genau hier klemmt es:

foobar.start()

kehrt ordnungsgemäß zurück, aber ausser beim ersten Aufruf, wird 'foobar.run()' nicht ausgeführt.
foobar.isAlive() liefert korrekt "false", der Thread läuft also nicht noch.
foobar.run() selber aufrufen ist irgendwie sinnbefreit, da sich damit die Nebenläufigkeit erledigt.

Hat jemand eine Idee, warum der Thread zwar sagt er sei nicht am Leben, die VM aber trotzdem 'run()' nicht aufruft?

Ich sehe ja ein, dass der Thread vielleicht nach einer Rückkehr aus 'run()' nicht mehr jungfräulichen Zustandes ist, und ich könnte auch damit leben, dass 'start()' dann nicht ohne weiteres will, *WENN* es etwas wie "reset()" gibt.

Ich will den Thread nicht jedes Mal neu erzeugen, da hängt eine LinkedList dran, die noch dazu ja bereits Elemente enthalten kann ... Dann wäre neu Erzeugen extrem doof, zumal ich nur *einen* Thread haben will, und keine zwei; Denn die könnten sich wieder mit Dateinamen gegenseitig in die Quere kommen.

Kann mir irgend jemand einen heißen Tipp geben? Wenn sich zu diesem Problem, dass 'start()' mehr erwartet als ich weiß, etwas in der offiziellen Java-Dokumentation findet, war ich zu blöd es zu finden und wäre auch für Hinweise diesbezüglich dankbar.

Vielen Dank im voraus

Peter
 

Mag1c

Top Contributor
Hi,

das Problem daß die Anwendung bei laufendem Thread nicht endet, kannst du mit setDaemon(true); lösen.

Einen beendeten Thread kannst du nicht neu starten. Der ist als Thread nicht mehr existent sondern nur noch als Java-Objekt(e). Du kannst deine ganze Logik und auch die Daten in eine Klasse packen, die das Iface Runnable implementiert. Davon hast du dann genau eine Instanz und du kannst mit new Thread(runnable).start(); einen neuen Thread damit starten. Eine Logik, daß nur ein Thread laufen darf, mußt du aber trotzdem selbst einbauen.

Gruß
Mag1c
 
P

Peetman

Gast
Hallo,

danke für die Antworten, das/die Tutorial/s werde ich mir nachher noch in einer ruhigeren Minute anschaun.

Mag1c hat gesagt.:
das Problem daß die Anwendung bei laufendem Thread nicht endet, kannst du mit setDaemon(true); lösen.

Ich weiß. Ich vergaß zu erwähnen, dass das keine sinnbringende Lösung für mein Problem ist, da dann auch das was der Thread macht gnadenlos gekillt wird. Und so ein Zwangsexit mitten im Packprozess ist meistens eher kontraproduktiv ;-)

Ich wollte gerne, dass der Thread die aktuelle Arbeit noch beendet, so dass die Applikation ggf. 1-2 Minuten später beendet wird und solange im "shutdown" verharrt.

Jedoch:

Mag1c hat gesagt.:
Einen beendeten Thread kannst du nicht neu starten. Der ist als Thread nicht mehr existent sondern nur noch als Java-Objekt(e).

erklärt dann, was da (nicht) los ist :-/ *grummel* *mift* Nagut ...

Mag1c hat gesagt.:
Du kannst deine ganze Logik und auch die Daten in eine Klasse packen, die das Iface Runnable implementiert. Davon hast du dann genau eine Instanz und du kannst mit new Thread(runnable).start(); einen neuen Thread damit starten. Eine Logik, daß nur ein Thread laufen darf, mußt du aber trotzdem selbst einbauen.

*hmmm* Klingt so, als könnte ich das hinkriegen ;-)

Danke für den Hinweis, das sieht vielversprechend aus.

Peter
 
P

Peetman

Gast
Hallo nochmal,

wie's aussieht habe ich es geschafft :)

Der HInweis mit dem Thread der kein Thread, sondern nur noch eine speicherverbrauchende Leiche, ist, sowie der Hinweis auf das Interface "Runnable" haben sehr geholfen.

Das Konstrukt, jeweils nur einen Thread das Runnable-implementierende Objekt auszuführen war dann eher Pippifax ;-)

Danke nochmal an alle (beide), und wenn ich wüßte, wie man die Frage des Themas als "Beantwortet" markiert, würde ich's tun ... :cool:
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
smarterToby Wie stoppe ich diesen Thread Allgemeine Java-Themen 4
A Thread.sleep Problem Allgemeine Java-Themen 2
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
Flynn Thread-Problem... Allgemeine Java-Themen 2
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
K Thread Problem 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
E Threads linkedlist/multi-thread problem Allgemeine Java-Themen 3
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
vandread Problem bei kleiner Thread-Übung 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
M Methoden Static Methoden und Thread??? Allgemeine Java-Themen 4
N java.lang.IllegalMonitorStateException: object not locked by thread before notify() Allgemeine Java-Themen 2
C Mehothode in anderenm Thread aufrufen Allgemeine Java-Themen 10
R Thread läuft nicht?! Allgemeine Java-Themen 7
R ThreadPool - vorhandene thread liste überprüfen bzw. aufräumen Allgemeine Java-Themen 3
J Anderem Thread Variable mitgeben Allgemeine Java-Themen 2
C Argument an einen Thread übergeben Allgemeine Java-Themen 4
S java.util.ConcurrentModificationException - aber nur ein Thread Allgemeine Java-Themen 3
G JUnit Test Methoden in anderen Thread verlagern Allgemeine Java-Themen 4
P Java Probleme - java.lang.Thread.run(Unkown Source) Allgemeine Java-Themen 10
L Im Thread auf Eingaben warten Allgemeine Java-Themen 3
P aus Thread auf Form zugreifen Allgemeine Java-Themen 9
C Threads Thread blockieren Allgemeine Java-Themen 4
K Threads Thread für Sleep Allgemeine Java-Themen 6
H Threads Thread stirbt aber Objekte in ihm leben weiter?! Allgemeine Java-Themen 9
K Threads Thread aktualisiert Progressbar nicht Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben