Threads bei quadcore

vimar

Bekanntes Mitglied
Hallo,

ich hab nun einen quadcore und will alle kerne zur berechnung nutzen. ich habe eine arraylist von objekten, diese unterteile ich in 4 bereiche und gebe jedem thread (habe 4 threads wegen 4 kerncpu) genau ein viertel der arraylist. die ganzen threads sind mit join() verknüpft. weiterhin rufe ich in einer schleife immer und immer wieder eine methode auf die diese threads neu startet um neue berechnungen zu machen. ich hatte schonmal einen threads "1000 threads oder iterativ" - hoffe also dass ich hier jetzt nicht mit einem neuen thread alle störe.

das problem ist: ich will permanente vollauslastung aller kerne haben. liegt es wohl am join() dass sagen wir am ende 3 threads auf den langsamsten thread waren, somit die auslastung von 99-100% runtergeht, der letzte thread fertig wird, die schleife erneut aufgerufen wird, alle threads wieder arbeiten, die schnellsten 3 wieder auf den langsamsten warten, cpu auslastung wieder runtergeht usw. hab hier ne abart sinuskurvige auslastung meiner 4 kerne.

hier ein bild:

der rote kasten zeigt die erzeugung von den 4 threads, alle werden gestartet und um blauen kasten gejoined. auf der linken seite sieht man meine threadklasse.

was für möglichkeiten habe ich? als ich die abarbeitung der arraylist nicht in 4 bereiche aufgeteilt habe sondern für jedes element ein eigenen thread erstellt habe (hatte dann so 1000 threads) wars einfach DEUTLICH schneller als mit 4 threads.

wie ist die richtige vorgehensweise, ich muss auf alle berechnung jedes threads warten.

threads.jpg
 

nrg

Top Contributor
ich hab mir jetzt nicht alles durchgelesen aber deine Threads haben mit den CPU-Threads nichts zu tun. Ein Single-Core/Thread-CPU kann auch ohne weiteres ein Programm ausführen, das 1000 Threads startet. Die Multiprocessing/threading-Fähigkeit haben alle CPUs, egal wieviel Kerne oder Threads. Ich denke du kannst es nicht programmatisch beeinflussen, auf welchen Threads/Kernen dein Programm läuft.
 

vimar

Bekanntes Mitglied

auf der page steht:

Die Implementierung von Java-Threads auf einem bestimmten Betriebssystem ist ein wichtiger Aspekt bei der Konstruktion einer Virtual Machine. Bei Betriebssystemen, die von Haus aus über Threads verfügen (so wie z. B. Solaris oder Windows NT/2000/XP), ist es prinzipiell möglich, Java-Threads direkt auf das Betriebssystem abzubilden.

...

Unter Windows NT/2000/XP werden Java-Threads auf Threads im Betriebssystems abgebildet, die innerhalb des Virtual-Machine-Prozesses ablaufen. Die Anzahl der gestarteten Prozesse und Threads kann auf dieser Plattform gut im Task-Manager beobachtet werden. Beim Starten eines Java-Programms sieht man, dass sich die Anzahl der Prozesse um Eins erhöht, die Anzahl der Threads nimmt dagegen stärker zu. Dies ist auch dann der Fall, wenn das Programm selbst keine eigenen Threads erzeugt, weil die Virtual Machine eigene System-Threads für Aufgaben wie Garbage Collection startet.

?

also es klappt schon wirklich, wenn ich die berechnung ohne threads mache, wird nur ein kern benutzt. und bei 4 threads auch 4 kerne.


die frage ist: wieviele threads muss ich nun machen?


ich habe ständig diese "pause": liegt es am join()???

hier ein bild:

threadpause.jpg


liegt es am join()? was kann ich tun?
 
Zuletzt bearbeitet:
G

Gast2

Gast
die frage ist: wieviele threads muss ich nun machen?
Das lässt sich nicht pauschal beantworten. Gute Werte sind meiner Meinung nach Anzahl Kerne oder Anzahl Kerne * 2. Die Anzahl der Kernen kannst du über
Code:
Runtime.getRuntime().availableProcessors();
auslesen.
 

vimar

Bekanntes Mitglied
Java:
System.out.println("kerne: " + Runtime.getRuntime().availableProcessors());

liefert als ergebnis: "kerne: 4".
 

vimar

Bekanntes Mitglied
rein logisch betrachtet muss es am join() liegen. es wird auf den letzten thread gewartet. und dieses gewarte lässt die anderen 3 kerne "ruhen". macht das sinn?

wenn das stimmt, so müsste es doch dennoch schneller laufen, weil der letzte thread weniger zeug zu berechnen hat als insgesamt. ohne eigene threads könnte ich einen kern dauerauslasten, aber theoretisch müsste das doch langsamer sein.
 

andiv

Bekanntes Mitglied
Informier dich doch mal über das Producer-Consumer-Problem und wie man das mit der java.concurrency-API elegant lösen kann. Das Buch Java Concurrency in Practice könnte dir dabei eine große Hilfe sein. Da werden auch so Fragen wie "Wieviele Threads sollte ich verwenden" ausführlich beantwortet.
 
Ä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 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
P Buffer - Consumer Producer - Threads synchronisieren Allgemeine Java-Themen 15

Ähnliche Java Themen

Neue Themen


Oben