Wieviele threads?

jabaduu

Bekanntes Mitglied
Moin, es heisst ja immer bei einem n Core Processor ist es am effizientesten n+1 threads zu benutzen. Aber was ist, wenn andere Leute das Programm auch benutzen sollen? Bietet man dann verschiedene Versionen für verschiedene Prozessoren an?
 

mrBrown

Super-Moderator
Mitarbeiter
Moin, es heisst ja immer bei einem n Core Processor ist es am effizientesten n+1 threads zu benutzen.
Wo heißt es das?

Aber was ist, wenn andere Leute das Programm auch benutzen sollen? Bietet man dann verschiedene Versionen für verschiedene Prozessoren an?
In Java? Nein.
Wenn du strikt "n Kerne = n+1 Threads" befolgen willst, dann kannst du in Java einfach die Anzahl an Kernen abfragen und entsprechend viele Threads starten.
 

httpdigest

Top Contributor
es heisst ja immer bei einem n Core Processor ist es am effizientesten n+1 threads zu benutzen
Schwachsinn.

Wieviele Threads für ein bestimmtes Problem optimal sind, hängt nicht von der Anzahl der Prozessoren ab, sondern von dem Problem. Bist du ALU-bound oder I/O-bound? Kannst du mehrere unabhängige Funktionen/Teile deines Algorithmus parallel laufen lassen ("functional parallelism") oder kannst du Parallelisierung über die Daten vornehmen ("data parallelism")? Außerdem ist der Parallelisierungsgrad deines Problems wichtig, siehe Amdahl's Law: https://en.wikipedia.org/wiki/Amdahl's_law, bzw. wie sehr Threads untereinander kommunizieren müssen.
Desweiteren ist wichtig, wie viel "Cache Trashing" dein Algorithmus betreibt und wie häufig unterschiedliche Threads dasselbe Datum bzw. dieselbe Cache Line im Speicher schreiben - da zumindest die x86-Familie Coherent Caching verwendet, also alle Prozessoren sehen immer denselben Speicherinhalt und müssen ihre Cache-Transaktionen untereinander austauschen, um das sicherzustellen.
 

jabaduu

Bekanntes Mitglied
ok httpdigest ich bin bei der suche über anzahl core und threads wohl in ein Unix Forum gekommen.
(Liegt wohl an meiner Migräne, liege seit 30 Stunden in einem abgedunkelten Raum mit höllische Kopfschm)
https://unix.stackexchange.com/ques...reads-makes-it-slower-than-using-less-threads
Aber da steht in den Antworten:
A common recommendation is n+1 threads, n being the number of CPU cores available. That way n threads can work the CPU while 1 thread is waiting for disk I/O.
Hat das denn so gar nichts mit meiner Frage zu tun?
 

httpdigest

Top Contributor
Wie ja schon alle anderen Antworten - inklusive der akzeptierten Antwort - in dem von dir referenzierten Thread sagen, hängt es von deinem konkreten Problem ab.
Zu sagen: "A common recommendation is n+1 threads, n being the number of CPU cores available. That way n threads can work the CPU while 1 thread is waiting for disk I/O."
ist in etwa vergleichbar mit der Frage "Wieviele Leute brauche ich, um Nägel irgendwo reinzuschlagen?" und einer Antwort darauf: "Optimal sind immer N+1 Leute, wobei N = Anzahl der Nägel, die du irgendwo reinschlagen musst" ohne auch nur im allergeringsten darauf einzugehen, wie dein Problem denn geartet ist, welches du versuchst, mit Multithreading zu lösen. Z.B.: Können denn gleichzeitig alle Leute irgendwo Nägel kloppen oder muss erst ein "Bauteil" fertig sein (Parallelisierbarkeit des Problems) , um es weiter verarbeiten zu können? Oder liegen die Plätze für die Nägel so dicht beieinander (wenige Millimeter), dass sich mehrere Personen nur gegenseitig stören und auf die Finger hauen würden, wenn sie versuchen, denselben Platz einzunehmen? (Sequentialisierung durch Nutzung gemeinsamer Ressourcen)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Wieviele Tage seit dem Datum vergangen sind Java Basics - Anfänger-Themen 5
H Wieviele Objekte gleichzeitig sind sinnvoll? Java Basics - Anfänger-Themen 4
B Wieviele bits belegen die Datentypen? Java Basics - Anfänger-Themen 2
G Wieviele Zeichen kann ein String maximal speichern? Java Basics - Anfänger-Themen 3
K Wieviele Befehle pro .java Datei Java Basics - Anfänger-Themen 4
M wieviele Tage der Monat X hat Java Basics - Anfänger-Themen 2
E wieviele objekte am heap?? Java Basics - Anfänger-Themen 14
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
C Threads und Swing Java Basics - Anfänger-Themen 9
berserkerdq2 Wo finde ich in der Java Api die Notation zu Threads bezüglich Synchronized? Java Basics - Anfänger-Themen 14
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
B Monitor als Schranke von Threads Java Basics - Anfänger-Themen 20
W Threads Alphabet Java Basics - Anfänger-Themen 20
H Threads Anfänger Java Basics - Anfänger-Themen 17
1 Threads parallel laufen Java Basics - Anfänger-Themen 11
B Threads Problem mit mehreren Threads Java Basics - Anfänger-Themen 38
M Threads Java Basics - Anfänger-Themen 12
L Threads Synchronisierung zwischen threads Java Basics - Anfänger-Themen 4
M Threads Java Basics - Anfänger-Themen 2
A Threads Java Basics - Anfänger-Themen 9
A Threads Java Basics - Anfänger-Themen 13
A Threads und .join Java Basics - Anfänger-Themen 14
W Threads starten Java Basics - Anfänger-Themen 2
X Threads Zwei Threads, aber doppelte Ausgabe verhindern (synchronized) Java Basics - Anfänger-Themen 54
J Problem bei seriellem Start von Threads Java Basics - Anfänger-Themen 11
O Threads Java Basics - Anfänger-Themen 2
L Buchungssystem und Threads Java Basics - Anfänger-Themen 2
O Threads - Synchronize(), join(), wait(), notify(), yield() Java Basics - Anfänger-Themen 6
L Klassen NFC Reader und JavaFx Problem -> threads? Java Basics - Anfänger-Themen 2
A Kommunikation zwischen nebenläufigen Threads Java Basics - Anfänger-Themen 4
S Gemeinsame Ressource und Mehrfachinstanziierung von Threads Java Basics - Anfänger-Themen 16
S Verklemmung Threads Java Basics - Anfänger-Themen 11
B Threads 2 Threads gleichzeitig laufen lassen Java Basics - Anfänger-Themen 1
M Threads Threads laufen sequenziell, statt gleichzeitig. Java Basics - Anfänger-Themen 9
M Threads run Methode Java Basics - Anfänger-Themen 4
javajoshi mehrere Threads: Methoden zentral unterbringen Java Basics - Anfänger-Themen 8
javajoshi Problem mit zwei Threads und Arrays (Runnable) Java Basics - Anfänger-Themen 12
L Threads Mit Threads JLabel ändern! Java Basics - Anfänger-Themen 2
K Matrixen berechnen nach Worker Master Paradigma mit Threads Java Basics - Anfänger-Themen 4
S Kleine Frage zu Threads Java Basics - Anfänger-Themen 3
M Mit 2 Threads eine Zahl hochzählen Java Basics - Anfänger-Themen 13
T Threads Synchronisieren Java Basics - Anfänger-Themen 6
D Frage Threads Java Basics - Anfänger-Themen 6
Z Threads Executor Framework - Aufgabe auf n Threads aufteilen Java Basics - Anfänger-Themen 10
Z Threads Threads - Zugriff auf Ressourcen ohne(Lock, Synchronized) Java Basics - Anfänger-Themen 2
kilopack15 Verständnisfrage zur Verwendung von notify() bei Threads Java Basics - Anfänger-Themen 2
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
H Threads funktionieren nicht Java Basics - Anfänger-Themen 4
J Aufgabe(Threads) richtig verstanden/implementiert Java Basics - Anfänger-Themen 27
R Threads aufeinander warten lassen? Java Basics - Anfänger-Themen 10
T Threads Durch threads gestartete Prozesse killen Java Basics - Anfänger-Themen 2
J Threads Java Basics - Anfänger-Themen 38
D Alte Klausuraufgabe Threads Java Basics - Anfänger-Themen 10
A Threads Threads bestimmte Aufgaben zuweisen... Java Basics - Anfänger-Themen 3
R Threads in JavaFX Java Basics - Anfänger-Themen 3
E Threads Doppelte Threads beenden Java Basics - Anfänger-Themen 4
F Sicheres Zurückmelden aus Threads Java Basics - Anfänger-Themen 0
G Threads zum Thema Threads??? null Ahnung Java Basics - Anfänger-Themen 4
Q Threads Threads in Swing Anwendungen Java Basics - Anfänger-Themen 5
J ConcurrentCalculation Multi Threads in Java Java Basics - Anfänger-Themen 3
P Threads Trotz Threads wird nur 1 Prozessorkern ausgelastet Java Basics - Anfänger-Themen 7
M "restartable" threads Java Basics - Anfänger-Themen 11
M Threads - summieren Java Basics - Anfänger-Themen 13
W Klassen Variable einer anderen Klasse ändern (Threads) Java Basics - Anfänger-Themen 3
E Threads - Programm analysieren Java Basics - Anfänger-Themen 2
E join() bei zwei Threads Java Basics - Anfänger-Themen 2
T Threads Threads richtig synchronisieren Java Basics - Anfänger-Themen 3
D [Concurrency/Threads] Code Umsetzung Schriftlich Java Basics - Anfänger-Themen 2
D Threads Java Basics - Anfänger-Themen 4
M Threads nio Dateien kopieren, Threads und Gui Java Basics - Anfänger-Themen 0
N Verweise auf Variablen in verschiedenen Threads Java Basics - Anfänger-Themen 4
T Java-Threads Java Basics - Anfänger-Themen 0
G Moving Objects with Threads (implements Runnable) Java Basics - Anfänger-Themen 1
F Threads funktionieren auf JPanel nicht Java Basics - Anfänger-Themen 1
M Problem mit Threads Java Basics - Anfänger-Themen 11
M Threads - wo gehören sie hin? Java Basics - Anfänger-Themen 3
S 2D-Spiel mit Threads... Java Basics - Anfänger-Themen 3
J Threads Java Basics - Anfänger-Themen 3
F ExecutorService und offene Threads Java Basics - Anfänger-Themen 3
P Threads Threads nicht nebenläufig Java Basics - Anfänger-Themen 7
M Threads nicht nebenleblaufig Java Basics - Anfänger-Themen 2
B Threads parallel zur main Java Basics - Anfänger-Themen 3
M Threads Java Basics - Anfänger-Themen 2
M Threads, zwei methoden gleichzeitig laufen lassen Java Basics - Anfänger-Themen 4
M Threads und Methodenübergreifender Variablezugriff Java Basics - Anfänger-Themen 2
J Wie handle ich Threads am besten? Java Basics - Anfänger-Themen 2
H Threads Java Basics - Anfänger-Themen 10
B synchronized threads Java Basics - Anfänger-Themen 17
E Mehrmaliges Ausführen eines Threads Java Basics - Anfänger-Themen 5
E Threads Verständnisfrage bzgl. Threads und Sleep Java Basics - Anfänger-Themen 2
T Alle Threads .notify() Java Basics - Anfänger-Themen 13
R Threads Verständnisschwierigkeit Java Basics - Anfänger-Themen 2
J Können mehere Threads parallel eine Datei lesen? Java Basics - Anfänger-Themen 4
G Methoden in Threads wandeln Java Basics - Anfänger-Themen 7
H Threads Java Basics - Anfänger-Themen 17
F Java Concurrency - Threads Java Basics - Anfänger-Themen 4
V Threads Threads synchronisieren Java Basics - Anfänger-Themen 4
T Threads Join() = Block? oO Java Basics - Anfänger-Themen 4
J Threads ArrayList Problem bei Threads Java Basics - Anfänger-Themen 3
C Objekte durchschleifen / Threads Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben