Konstante Zahl Threads parallel rechnen lassen

Status
Nicht offen für weitere Antworten.

Ede_123

Mitglied
Hi,

ich bin mir sicher, dass ich nicht der Erste sein kann der dieses Problem hat, jedoch suche ich scheinbar nach den falschen Begriffen, oder gehe von vornherein ganz falsch an das Problem heran, denn bis jetzt habe ich noch nichts brauchbares gefunden.

Es geht um folgendes:
Ich habe eine Klasse (abgeleitet von Thread) die Berechnungen vornimmt. Diese Berechnungen sind voneinander unabhängig.

Ich möchte nun dass ständig mehrere dieser Threads ihre Arbeit verrichten (am besten soviele wie es Rechenkerne gibt), d.h. z.B. 4 Threads gestartet werden und erst wenn einer davon fertig ist, der nächste gestartet wird. Wie implementiere ich das sinnvoll?

Unten der Code, den ich bisher habe (der, der in der Main-Methode aufgerufen wird), dieser produziert allerdings (ist ja logisch) selbst schon eine sehr hohe CPU-Auslastung (sorry, irgendwie kann ich keinerlei formatierungen vornehmen, werde versuchen das bei Gelegenheit nachzuholen):

Java:
for(int x=0; x<irgendwas; x++) { //läuft durch alle "x" die berechnet werden müssen
	while(Thread.activeCount()>=4) {}; 	//<- führt selbstverständlich zu hoher CPU-Last
										//ein sleep() an dieser Stelle scheint die komplette Berechnung auszubremsen
	CalculationThread thread = new CalculationThread(x);
	thread.start();
}
 
Zuletzt bearbeitet:
M

MiDniGG

Gast
Also formatieren kannst Du mit [ JAVA] [/code] diese Java-Tasse da ^^

Wenn ich Deine Frage richtig verstanden habe würde ich es so machen:

Java:
for(int x = 0; x < grenze;) { //diese klammer ist bei Dir nicht...
     if(Thread.activeCount() < 5) {
          CalculationThread thread = new CalculationThread(x);
          thread.start();
          x++;
     }
}

Somit wird nur ein neuer Thread gestartet, wenn nicht schon 4 laufen... Damit die Schleife nicht schon zu früh aus is wird x auch nur erhöht, wenn ein Thread gestartet wird... Weiß nicht ob das Ideal ist. Aber es sollte Deinem Problem entgegenwirken :D
 

newcron

Aktives Mitglied
Auch wenn es prinzipiell immer gut ist, vorhandenes zu verwenden (ThreadPoolExecutor) hier dennoch eine Antwort auf die Frage:
Du würdest in deiner while (Thread.activeCount()>=4) {}; den Verwaltungsthread einfach mittels Thread.sleep(100) schlafen legen. Dann wird der vom VM Scheduler für 100ms Sekunden nicht mehr aufgerufen. In diesen 100ms Verbrät diese While schleife, die du in irgend einer Form benötigen würdest, keine CPU zeit.

Übrigens habe ich mal gehört, dass die Sun JVMs höchstens zwei Prozessoren verwalten können. Ob das noch immer/überhaupt stimmt, weiß ich nicht. Wie viele Prozessoren tatsächlich verfügbar sind, erfährst du mit Runtime.getRuntime().availableProcessors()
 

Ede_123

Mitglied
@MiDniGG: Danke, da hab ich nen Fehler eingebaut - Die Java-Tasse war nicht da, weil ich irgendwie in der Forensoftware ein eingeschränktes Interface eingestellt hatte
Zum Problem: Das was du beschreibst senkt die CPU-Last doch auch nicht? Nur statt in der while-Schleife, hängt er dann halt in der for-Schleife?

@Landei: Auf ThreadPoolExecutor bin ich während meiner Recherche schon mal gestoßen, ist mir in dem Moment allerdings für mein Problem zu aufwändig/unpassend erschienen, werde es mir jedoch noch mal anschauen.

@newcron: Ein sleep() einzubauen hatte ich ebenfalls versucht, allerdings sinkt die CPU-Last auf meinem System dann auf ~20% und die Berechnung dauert ewig - irgendwas bremst in diesem Fall gewaltig aus (hatte für sleep werte von (100,10,1)ms sowie (100,10,1)ns probiert, daran kanns wohl nicht liegen).

Soweit vielen Dank schon mal, falls ihr noch andere Ideen habt, nur her damit!
 

Ede_123

Mitglied
Super faetzminator!
yield() scheint die Lösung zu sein, ich muss zwar nochmal genau testen, aber es scheint die CPU-Last des Main-Threads angenehm niedrig zu halten.

Ich denke das war die einfachste und zugleich wirkungvollste Lösung für mein Problem!
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
X Collections Gibt es eine Klasse welche die Vorteile von List und HashMap vereint, aber konstante Laufzeit (O(1)) hat in Java? Allgemeine Java-Themen 4
F Konstante an main - Argumenten initialisieren Allgemeine Java-Themen 1
U Konstante in Objekt definieren Allgemeine Java-Themen 6
Tom299 eine Konstante in Spring definieren? Allgemeine Java-Themen 4
O Dateinamen mit Zahl um eins erhöhen Allgemeine Java-Themen 16
B Millionen bit lange zahl bauen? Allgemeine Java-Themen 7
J Zerlegen einer Zahl Allgemeine Java-Themen 6
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
Tronert Alphabetische Aufzählung aus Zahl? Allgemeine Java-Themen 5
E String in Zahl umwandeln, ohne Befehl Integer.parseInt Allgemeine Java-Themen 3
E Swing andere schreibart für jButtoni (i = Zahl des Buttons) Allgemeine Java-Themen 6
J Eine bestimmte Zahl im Integer ändern Allgemeine Java-Themen 9
J While Schleife ausführen bis Zahl = X Allgemeine Java-Themen 19
J Repräsentation in Java - 32bit Zahl Allgemeine Java-Themen 8
T Quadrieren einer Zahl nur durch Addition Allgemeine Java-Themen 5
Z Zahl raten Allgemeine Java-Themen 2
Chr1s ergebnis = Zahl? Allgemeine Java-Themen 3
A Zahl abgerundet obwohl Double Allgemeine Java-Themen 9
K Interpreter-Fehler Java Zahl Raten Spiel- Fehlermeldung mir unbekannt Allgemeine Java-Themen 12
J Die Menge einer Zahl im Binärbaum zählen Allgemeine Java-Themen 7
P Input/Output java.util.Scanner in einer Schleife und Exception-Behandlung: Einlesen einer Zahl Allgemeine Java-Themen 4
A Zahl zu lang für Long Allgemeine Java-Themen 3
L Leerzeichen zu string hinzufügen, um eine gerade zahl zu erhalten Allgemeine Java-Themen 9
O Prüfen ob String eine Zahl mit maximal 2 Nachkommastellen ist Allgemeine Java-Themen 4
N Zahl mit bestimmter Länge und nur bestimmten Zahlen generieren lassen Allgemeine Java-Themen 7
J Bestimmter Buchstabe = bestimmte Zahl Allgemeine Java-Themen 10
H Eclipse x Stellen einer Zahl in array speichern Allgemeine Java-Themen 3
S Antlr Grammatik übersetzt ohne Fehler, dennoch wird Zahl nicht als Eingabe erkannt Allgemeine Java-Themen 4
C Zahl im Textarea anzeigen lassen Allgemeine Java-Themen 8
C Regex: Zahl ohne führende Null Allgemeine Java-Themen 13
cedi int Zahl in ein ASCII zeichen umwandeln und dieses in ein externes Textfenster schreiben Allgemeine Java-Themen 6
Rudolf Aus Collection<Integer> eine Zahl machen Allgemeine Java-Themen 2
M Zahl aktiver Threads einer Gruppe verlässlich abfragen Allgemeine Java-Themen 3
C Prüfen auf Zahl und 6 stellig fehlerhaft? warum? Allgemeine Java-Themen 7
S Zahl konvertieren [Internationalisierung l10n, l18n] Allgemeine Java-Themen 4
T Zufallszahlen generieren und dabei eine Zahl weglassen Allgemeine Java-Themen 4
Z Zahl einer spanne zuordnen Allgemeine Java-Themen 2
FoolMoon Elegante Möglichkeit die kleinste Zahl zu ermitteln. Allgemeine Java-Themen 7
L Berechnung mit Module bis bes.timme Zahl erreicht. Allgemeine Java-Themen 4
Ark O-Notation und Zahl versus String-Repräsentation Allgemeine Java-Themen 7
N int[] eindeutig durch eine Zahl repräsentieren Allgemeine Java-Themen 12
D Regular Expression Mit Punkt und Zahl Allgemeine Java-Themen 4
X Substring aus Zahl Allgemeine Java-Themen 8
G Auf eine ganze Zahl aufrunden Allgemeine Java-Themen 30
G Zahl aus dem String Allgemeine Java-Themen 6
K Double-Zahl runden Allgemeine Java-Themen 4
L Partitionen der Länge x einer natürlichen Zahl n Allgemeine Java-Themen 21
G Prüfen ob Ziffern einer Zahl pandigital sind? Allgemeine Java-Themen 15
J Große Zahl (double) as text ausgeben? Allgemeine Java-Themen 2
0 Alle Teiler einer Zahl performant berechnen? Allgemeine Java-Themen 9
G Double Zahl quadrieren Allgemeine Java-Themen 8
G String in Zahl umwandeln Allgemeine Java-Themen 9
C Server-Zahl von google.com Allgemeine Java-Themen 11
B Umwandeln von Bytes in float Zahl (DataInputStream) Allgemeine Java-Themen 3
H ganze zahl true / false Allgemeine Java-Themen 3
M Umwandeln String (mit Zahl zur Basis 36) in Dezimalzahl Allgemeine Java-Themen 2
N Float zahl auf eine Stelle nach dem Komma runden Allgemeine Java-Themen 3
G Double Zahl auf 4 Stellen hinter Komma kuerzen Allgemeine Java-Themen 4
S addAtPosition - Zahl an einer bestimmten Position einfügen Allgemeine Java-Themen 8
G String als Zahl erkennen Allgemeine Java-Themen 19
N Zahl mit DecimalFormat formattieren Allgemeine Java-Themen 2
R Zahl eingeben! Allgemeine Java-Themen 9
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

Ähnliche Java Themen

Neue Themen


Oben