ExecutorService Frage (concurrent Threads)

Sekundentakt

Bekanntes Mitglied
Hallo Gemeinde,

ich habe ein paar Fragen zum ExecutorService.

Hier mal ein paar Code-Beispiele:
Java:
while(someCondition)
   executorService.execute(new MyRunnable(mapToWorkOn)); //Hier erhalte ich irgendwann eine Exception, dass die maximale Anzahl an Threads erreicht ist.

Java:
MyRunnable t = new MyRunnable(mapToWorkOnQueue);
while(someCondition)
   executorService.execute(t);

Im ersten Beispiel laufe ich irgendwann in eine Exception, die mir sagt, dass zuviele native Threads erzeugt wurden.
Im zweiten Beispiel passiert das nicht. Ich vermute, dass das daran liegt, dass ich keine neuen MyRunnable-Objekte erzeuge, sondern immer das Selbe Objekt übergebe.
Mich würde jetzt interessieren, ob der executorService im zweiten Beispiel trotzdem jeden MyRunnable parallel ausführen lässt, oder nicht.
Der Unterschied zwischen beiden Versionen ist, dass der MyRunnable im zweiten Fall seine Daten aus einer Queue bezieht, diese also nicht immer neu via Konstruktor übergeben werden brauchen.

Das beabsichtigte Verhalten wäre, dass so viele MyRunnable-Instanzen wie nur möglich parallel Daten aus der Queue verarbeiten.

Welches der beiden Codebeispiele wäre hier der richtige Ansatz?
Oder gibt es da noch andere?
Referenzen zu BestPractices oder Ähnlichem sind immer gerne gesehen.

Beste Grüße
- Sekundentakt
 
Zuletzt bearbeitet:

Frank1975

Mitglied
Der 1. Ansatz ist der einzige "gute" Ansatz.

fraglich ist nur, warum Du so viele Threads nebeneinander machen musst. Je nachdem
was in dem Thread passiert verbraucht der einzelne Thread eine menge Speicher,
der irgendwann nicht mehr allokiert werden kann.

Ich habe mal eine Volltextindizierung gemacht und bin auf knappe 100 Threads gekommen.
Mehr hätten es zwar sein können jedoch ließ ab einer bestimmtenb Grenze die CPU Power dann nach,
so dass es fast so schnell war wie 10 Threads.

Ich würde eine Grenze setzen. Array und den mit x Threads füllen.

lass doch mal in Deiner Schleife einen Counter zählen und ausgeben wie viele Threads Du
generiert hast und dann siehst Du auch wann er aussteigt.
 
Zuletzt bearbeitet:

Marco13

Top Contributor
Ähm ... *räusper*.... entweder ich habe bei ExecutorService etwas falsch verstanden, oder du, oder oder Name "MyThread" ist schrecklich unpassend, aber ... eigentlich dachte ich, dass man einem Executor ein Runnable übergibt - und nicht einen eigenen Thread. Die Threads verwaltet der Executor nämlich intern selbst, und man kann z.B. mit Executors (Java 2 Platform SE 5.0) einen erstellen, dem man von vornherein sagt, wie viele Threads er haben soll, oder Executors (Java 2 Platform SE 5.0) verwenden, wenn man die Anzahl vorher nicht kennt. Aber einen Thread statt eines Runnable übergeben sollte man da mit Sicherheit nicht...
 

Sekundentakt

Bekanntes Mitglied
Hallo,

danke für euer Feedback!

@Marco: Na klar, es geht um Runnables. myThread ist wirklich ein scheußlicher Name. Ich änder das mal.

@ Frank1975: Danke für den Hinweis. Ich werde das mal gleich umsetzen. :)

Ich habe jetzt einen FixedThreadPool mit einer Anzahl von 10 eingestellt, das spart den Counter und macht nach Deinen Ausführungen mehr Sinn ;).
Btw: Meine Aufgabe widmet sich ebenfalls der Textverarbeitung.
Allerdings habe ich im Moment eine Lösung, die vom Code her eine Mischung der beiden Beispiele ist:

Java:
mapToWorkOnQueue.put(data);
while(someCondition)
   executorService.execute(new MyRunnable(mapToWorkOnQueue)); //Hier erhalte ich irgendwann eine Exception, dass die maximale Anzahl an Threads erreicht ist.
Die Queue ist eine LinkedBlockingQueue und bietet mir den Vorteil, dass der Producer warten muss, bis die Consumer die Queue etwas geleert haben.
Ich bin gerade am Überlegen, ob ich statt eines put() lieber ein offer() mit TimeOut verwenden sollte.
Pro: Der Producer muss nicht nur warten bis Platz in der Queue ist, sondern etwas länger, sodass den Consumern mehr Arbeitszeit zugeteilt werden kann.
Kontra: Ist das nicht ein Nullsummenspiel? Und wenn nicht, sollte ich die Kapazität der Queue auf die Anzahl der Threads beschränken, die maximal ausgeführt werden können oder etwas darüber liegen?

Ich spiele da mal ein bisschen herum. Falls es zu solchen Szenarien Erfahrungen gibt, kann man sich im Nachhinein über die Ansätze austauschen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F ExecutorService richtig anwenden Allgemeine Java-Themen 0
M ExecutorService, fängt nicht an Allgemeine Java-Themen 1
F ExecutorService sauber stoppen Allgemeine Java-Themen 8
S ExecutorService.invokeAll -- was passiert wenn einige Tasks schon ausgefuehrt wurden? Allgemeine Java-Themen 2
K Parallel programmieren mit ExecutorService Allgemeine Java-Themen 41
M callable in ExecutorService killen? Allgemeine Java-Themen 14
C Threads ExecutorService shutdown abbrechen und service "starten" ? Allgemeine Java-Themen 3
D Thread.setUncaughtExceptionHandler() für ExecutorService Allgemeine Java-Themen 4
C JProgressbar an ExecutorService koppeln Allgemeine Java-Themen 5
O Unterschied zwischen Semaphoren/Lock und ExecutorService Allgemeine Java-Themen 3
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben