Threads bestimmten Kernen zuweisen?

truesoul

Top Contributor
Hi.

Nein ist es nicht und wäre fatal, so wie Marcinek sagte.
Das einzige was man machen kann, die Prioritäten setzen.
Aber selbst das würde ich nicht empfehlen.
 

hdi

Top Contributor
Das einzige was man machen kann, die Prioritäten setzen
Wobei ich glaube dass damit nur die Priorisierung innerhalb der Applikation gemeint ist, und nicht innerhalb der globalen Betriebssystemumgebung. Nicht, dass der TO hier die Prio hochsetzt und meint damit wird sein Programm favorisiert. Oder irre ich mich? Genau wissen tu ich's leider nicht.
 
I

irgendjemand

Gast
kann mich meinen vorrednern nur anschließen ...

1) java läuft in einer VM ... also hat die VM gegenüber dem code beliebig resourcen wie RAM , CPU (-kerne) und andere dinge
2) es wäre nicht im sinne von java *plattformunabhängigkeit !* wenn du etwas so system-spezifisches festlegen könntest
3) kleines beispiel : sagen wir du hast einen quad- oder hexa-core und schreibst deinen code so das explizit core 3 *also den 4ten kern *in der pc technik beginnt man schließlich immer bei 0 zu zählen** zuweist ... ist das ja noch kein problem so lange die CPU über mindestens 4 kerne verfügt und damit diesen core #3 hat ...
wüdest du das ganze nun aber auf nem single- , dual- oder triple-core versuchen ... würde es fatale fehler geben da es dort core #3 nicht gibt ... sondern max core #2 ...
du siehst also : dein code könnte nur auf systemen laufen welche mindestens deinem entsprechend oder besser sind ... mit system welche weniger resourcen haben dürfte es neben leichten fehlen auch komplett abstürze geben ...
4) man kann versuchen an den thread-präoritäten rumzuspielen ... aber es gibt systeme und sicherheitsrichtlienien *zumindest unter windows* die sowas blockieren und damit wirkungslos machen können ...

um deine frage also mit einem wort zu beantworten : NEIN
 
G

Gast2

Gast
Ist es möglich genau zu bestimmen welcher Thread von welchen CPU Kern behandelt werden soll?
ja - aber ... Java kann das nicht von Haus aus (Java7??) ... der Link von Maki scheint aber nur Linux abzudecken ... wenn Du das für Windows benötigst musst Du mal die API durchsuchen und selber was basteln mit JNI ... könnte auch sein das sich beide Betriebssysteme an POSIX halten und der Kram in POSIX standardisiert ist (vgl. vanilla.java.affinity.impl.PosixJNAAffinity) - denke aber eher nicht

es wäre nicht im sinne von java *plattformunabhängigkeit !* wenn du etwas so system-spezifisches festlegen könntest
eine CPU ist also Plattformabhängig ... eine Grafikkarte nicht

kleines beispiel : sagen wir du hast einen quad- oder hexa-core und schreibst deinen code so das explizit core 3 *also den 4ten kern *in der pc technik beginnt man schließlich immer bei 0 zu zählen** zuweist ... ist das ja noch kein problem so lange die CPU über mindestens 4 kerne verfügt und damit diesen core #3 hat ...
wüdest du das ganze nun aber auf nem single- , dual- oder triple-core versuchen ... würde es fatale fehler geben da es dort core #3 nicht gibt ... sondern max core #2 ...
ganz schlechtes Beispiel ... oder ein gutes Beispiel für nicht nachgedacht bei der Programmierung ... als erstes prüft man ob auch genügend Kerne vorhanden sind um einen Thread auf einem Kern fest zunageln

ansonsten - was willst Du machen?? ... es macht nur in 2 Dingen Sinn einen Thread auf einen Kern fest zunageln (lasse mich gern eines besseren belehren)

hand, mogel
 
S

SlaterB

Gast
warum reden hier viele von fatal, teils wird Plattformunabhängigkeit bestritten?
die ursprüngliche Frage wurde in einer einzigen Zeile formuliert, da konnte man gar nicht viel böses reinstecken außer vielleicht das Wort 'genau'..

niemand verlangt (bisher unbedingt), dass eine genaue Zuordnung auch immer ausgeführt werden muss,
genau wie Thread-Priorität nur ein Hinweis ist, genau wie repaint()-Aufruf eine Aufforderung, kein Befehl ist,
könnte man doch die x Threads im Programm mit Ausführhinweisen hinterlegen:

Thread A auf CPU 1, B CPU 2, diese 3 CPU 3, jene 5 CPU 4,
wenn nur eine CPU, dann wird trotzdem alles dort gemacht,
wenn 2 CPUs vorhanden sind könnte Java sich dazu entscheiden A und B auf einer, die restlichen 8 Threads auf der anderen laufen zu lassen usw.,
(edit: bei irgendwann mal 100 CPUs kann immer noch einer pro Thread verwendet werden,
statt sie unnötig zusammenzupressen)

besser als gar keine Hinweise allemal, was sollte davon fatal kaputtgehen?

dass es das vielleicht überhaupt nicht gibt, dass das dem Konzept der Thread-Priorität entgegensteht, könnte man anmerken,
aber bisschen weniger nörgeln wäre doch auch nicht schlecht ;)
 
Zuletzt bearbeitet von einem Moderator:
Ähnliche Java Themen
  Titel Forum Antworten Datum
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 Wieviele threads? Java Basics - Anfänger-Themen 9
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
J Threads stoppen mit interrupt - Frage dazu Java Basics - Anfänger-Themen 7
N Pingen in Threads Java Basics - Anfänger-Themen 9
B Threads benutzen Java Basics - Anfänger-Themen 5
E Allgemein Verständnissfrage zum Ablauf mehrerer Threads Java Basics - Anfänger-Themen 4
S Threads erzeugen Java Basics - Anfänger-Themen 11
K Threads Nur 2 von 3 Threads funktionieren Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben