Threads kontrollieren

Status
Nicht offen für weitere Antworten.
Hallo liebe Forengemeinde,

Ich arbeite seit ein paar Wochen mit Java und stoße gerade auf ein Problem, dass ich auch mit meinen Büchern nicht gelöst bekomme.

Ich möchte in meiner main einen Prozess drei mal starten. Dann soll ein mal pro Sekunde überprüft werden ob einer der drei Prozesse fertig ist. Für jeden fertigen Prozess soll wieder ein neuer gestartet werden, so dass immer drei Prozesse parallel laufen und meine Daten verarbeiten.

Das alleine wäre ja nicht das Problem. Ich benenne diese einfach Prozess A, B und C und füge diese hartcodiert ein.

Nun kommt aber mein Problem ...

Ich möchte beim Programmstart zwei Variablen übergeben. Die eine soll die Anzahl der Prozesse steuern, dass man je nach Rechenleistung mehr oder weniger einstellen kann. Die andere soll die maximale Laufzeit in Sekunden für einen Prozess angeben. So dass ein Prozess, der mit seinen Berechnungen nach X Sekunden nicht fertig ist automatisch abgebrochen und ein neuer gestartet wird.

Und genau da scheitere ich derzeit ...

Wie soll ich da vorgehen oder gibt es da schon irgendwo einen Codeschnipsel an dem ich mich orientieren kann?

Gruß

DerProgrammierer78
 
Das liest sich interessant und könnte mein Problem evtl. lösen ... leider weiss ich nicht, wie ich das anwenden kann und werde auch aus dem Beispiel oben auf der Seite nicht schlau, da ich es da nicht finde ...

#edit

Ich meine da ich nicht finde, wie ich es da einbauen muss ...
 
Zuletzt bearbeitet:

Paddelpirat

Bekanntes Mitglied
Habe gerade auch mal etwas mit der Klasse ExecutorService rumgespielt, aber ich glaube das Verhalten was DerProgrammierer78 sucht kann man damit nicht 100%ig nachbilden.

Für den Fall der 3 parallelen Threads:

Die Methode invokeAll() versehen mit einem Timeout kommt erst zurück, wenn alle 3 aufgetragenen Aufgaben von den Threads abgearbeitet wurden, bzw. im worst case vom Timeout beendet worden sind. Erst danach kann man 3 neue Aufgaben an die Threads weiter geben.

Die Methode invokeAny() versehen mit einem Timeout kommt zurück, nachdem eine der drei Aufgaben abgearbeitet worden ist. Die anderen Aufgaben werden einfach abgebrochen...

Und die Methode submit() mit der man ein Future Objekt erhält, was man wiederum per get()-Methode mit einem Timeout versehen kann blockiert nach jedem Einzelaufruf einer Aufgabe, bis sie zurückkommt oder im worst case per Timeout beendet wird.

Von daher bleibt wohl nichts anderes übrig als für jeden Thread, der eine Aufgabe abarbeiten soll auch noch zusätzlich einen Timer-Thread zu erstellen, der überprüft wie lange die Ausführung bereits andauert. Oder habe ich etwas übersehen und es geht doch einfacher? (Interessiert mich auch weil ich mal sowas ähnliches programmiert hatte...)
 
Hallo Paddelpirat,

Danke für deine Antwort ...

Das würde ich so machen, wenn ich wüsste wie ich Werte aus einem Thread in einem anderen Thread abfragen kann und dann den abgefragten Thread beenden kann.

Weil dann würde ich beim starten eines Threads die Startzeit in diesem in eine Variable legen, die ich in einem anderen dann abfrage.

Gruß

DerProgrammierer78
 

Paddelpirat

Bekanntes Mitglied
Ich denke ein Thread für die Zeitkontrolle aller Prozesse würde auch reichen. Hier die Idee dazu:

Zuerst erstellst du dir einen Prozess der etwa so aussehen kann (die Abfrage mit dem !timedout musst du so platzieren, dass die Schleife in der sich der Prozess aufgehangen hat abbricht):

Java:
class MyProcess implements Runnable
{
	boolean timedout = false;
	
	public MyProcess() {
		
	}
	
	public void run() {
		while(!timedout) {
			doSomething();
		}
	}
	
	public void setTimedout() {
		this.timeout = true;
	}
	
	private void doSomething() {
		
	}
}

Dann könntest du eine Hashtable oder ähnliches anlegen in der du den Prozess und die Startzeit festhälst.

Ein weiterer Thread prüft dann jede Sekunde (oder halt so Zeitnah wie du es brauchst), ob einer der Prozesse in der Hashtable abgelaufen ist. Wenn ja wird, falls der Prozess überhaupt noch existiert, die Methode setTimedout() des Prozesses aufgerufen, so dass dieser beendet wird. Anschließend kannst du das Wertepaar bestehend aus Prozess und Start-Zeit aus der Tabelle schmeißen.

Naja das wäre jetzt mal ein erster Ansatz... weiß halt nicht, ob es noch schöner geht.
 
Zuletzt bearbeitet:
Hallo Paddelpirat,

Vielen Dank für deine Antwort, aber irgendwie bleibt der in meinem Code immer an dieser Stelle hängen:

Java:
URLConnection url_connection = url_internet.openConnection();
try
{
    BufferedReader br = new BufferedReader(new InputStreamReader(url_connection.getInputStream()));
    HTMLEditorKit editorKit = new HTMLEditorKit();
    HTMLDocument htmlDoc = new HTMLDocument();
    htmlDoc.putProperty("IgnoreCharsetDirective", Boolean.TRUE);
    ...
    ... do something with loaded data
    ...
}
catch (Exception e)
{
   ... write error message to database
}

Er kommt also gar nicht erst zum Ende der While-Schleife

Gruß

DerProgrammierer78
 
Also ich habe nun zumindest schonmal eine Teillösung ...

Diese habe ich in einem Buch gefunden ...

Java:
public void run()
{
    try
    {
        while (!Thread.currentThread().isInterrupted() && Was zu tun)
        {
            ... arbeiten ... arbeiten ... arbeiten ...
        }
    }
    catch(InterruptedException e)
    {
        ... arbeiten beenden und ggf. Status ins Logfile schreiben ...
    }
    finally
    {
       ... aufräumen ...
    }
}

Nun frage ich mich aber, wie man einen Interrupt von einem Thread an einen anderen schicken kann, damit der eine den anderen beendet ???


Gruß

DerProgrammierer78
 

André Uhres

Top Contributor
Es gibt Thread#interrupt(), allerdings ich bin eher dafür, einen eigenen boolean "running" auf "false" zu setzen.
 
Hallo André Uhres,

Danke für deine Antwort :)

Das habe ich versucht ... Leider bleibt er hängen und kommt nicht zum Ende der while(isRunnung)-Schleife ...

Wenn du dafür eine Lösung hättest, dann würde ich mich über diese freuen :)

Gruß

DerProgrammierer78
 

Paddelpirat

Bekanntes Mitglied
Kannst du nochmal etwas mehr Code reinstellen und zeigen, wie du versucht hast die Schleife bzw. generell den Prozess zum Abbruch zu bringen? Bzw. versteh ich gerade nicht, wo genau es hängen bleibt ohne dass der Prozess abgebrochen wird...
 
Hallo Paddelpirat,

Ich habe im Endeffekt nur das was oben steht in eine While-Schleife gepackt und der BufferedReader hört bei größeren Datenmengen oder wenn die Leitung zu langsam ist einfach nicht auf zu laden. Und das will ich umgehen, weil das meine restlichen Prozesse nur unnötig ausbremst. Dann lade ich lieber erst was anderes und kehre dann nochmal zu dieser Quelle zurück ...

Gruß

DerProgrammierer78
 

Paddelpirat

Bekanntes Mitglied
Mein Verständnisproblem liegt nur darin, dass du in dem Code, den du oben gepostet hast ja eigentlich nur die Verbindung zu irgendeiner URL aufbaust und diese jetzt über den InputStreamReader an den BufferedReader übergibst.

Das eigentliche Einlesen müsste ja erst noch kommen z.B. mit so etwas wie:

Java:
String zeile = br.readLine();
while(zeile != null) {
    System.out.println(zeile);
    zeile = br.readLine();
}

So und diese Schleife kannst du nun mit einer weiteren Variablen, z.B. dem boolean timedout erweitern:

Java:
String zeile = br.readLine();
while(zeile != null && !timedout) {
    System.out.println(zeile);
    zeile = br.readLine();
}

Wobei du das timedout halt über einen anderen Timer-Thread irgendwann auf true setzt. Dann ist das Einlesen vorzeitig beendet...
 
Achso ... das meinst du ... Sorry.... :)

Java:
editorKit.read(br, htmlDoc, 0);
HTMLDocument.Iterator iter = htmlDoc.getIterator(HTML.Tag.VAR);
while (iter.isValid())
{
    ... hole Daten aus den Variablen und speichere diese in der Datenbank ...
}

Aber er hört schon auf bei "editorKit.read(br, htmlDoc, 0);" ...
 

Paddelpirat

Bekanntes Mitglied
Okay jetzt wirds unschön *g*... ich bezweifle, dass die Methode read() auf ein interrupt reagiert, aber man könnte das ganze umgehen und in einer while schleife verpacken:

Java:
BufferedReader br .... //wie in deinem Programm

String zeile = br.readLine();
ByteArrayInputStream bais = new ByteArrayInputStream(zeile.toArray());

while(zeile != null && !timedout) {

    editorKit.read(bais, htmlDoc, htmlDoc.getLength);
    bais = new ByteArrayInputStream(br.readLine().toArray());
}

br.close();

D.h. du verpackst jede Zeile des HTML Dokumentes in einem ByteArrayInputStream und lliest diesen dann in dein EditorKit rein.

Habs nicht ausprobiert ob es so klappt, aber das müsstest du ja schnell mal bei dir so einfügen können.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
A Problem mit der Synchronisierung von Threads Allgemeine Java-Themen 15
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
E Verständnisfrage bezüglich Threads Allgemeine Java-Themen 4
K Zeitkritische Threads Allgemeine Java-Themen 14
K Threads - Swing - Synchronisation nötig? Allgemeine Java-Themen 8
S [THREADS] Thread sinnvoll beenden Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben