Frage bzgl ExecturoService

Status
Nicht offen für weitere Antworten.
B

bygones

Gast
Hi,

ich habe folgendes Szenario:

Ich will eine Reihe von asychronen Thread starten lassen und die Ergebnisse nach max. X sekunden holen (wenn frueher da sind, dann natuerlich frueher). Sind alle Threads beendet (sei es weil sie durch gelaufen sind oder wegen timeout), dann geht das Programm normal weiter.

Ich hab ein bisschen rumgesucht und bin dabei auf ExecutorService und Callable gestossen - da ich noch nicht viel erfahrung da habe - also im sinne von gar keiner - wollte ich mal nachfragen ob das dafuer verwendbar ist und / oder obs etwas besser passendes gibt

Code:
public class Test() {
 private static final int TIMEOUT = 5;
 
 public static void main(String[] args) {
   Callable<String> c1 =  createCallable(); // also irgendein Callable erzeugen
   Callable<String> c2 = createCallable(); // und noch eins
   
   ExecutorService executor = Executors.newCachedThreadPool(); // oder auch fixed pool
   Future res1 = executor.submit(c1);
   Future res2 = executor.submit(c2);

   String result1 = res1.get(TIMEOUT, TimeUnit.SECONDS);
   String result2 = res2.get(TIMEOUT, TimeUnit.SECONDS);

  // und irgendwie weiter
 }
}
ich hab mal das exception handling weggelassen...

was mich ein bisschen stoert ist, dass ich somit nicht auf jeden Thread X Sekunde warte, sondern wenn der 1. Thread z.b. nach 5sec nichts liefert, wird der 2. abgefragt - auch 5sek lang... d.h. der kann insg 10sec laufen....

Ist das anders moeglich - OHNE komplett eigenes Thread start run stop interrupt join sich zu basteln ?

danke

ps: gern gesehen sind auch gute seiten / erklaerungen ueber Executor und Konsorten....
 

byte

Top Contributor
Hoffe ich hab Dich richtig verstanden: Guck Dir mal java.util.concurrent.ExecutorCompletionService<V> an.
 
B

bygones

Gast
danke - das schaut schonmal besser aus vom handling her...

problem ist theoretisch immer noch bei dem pull der Klasse.

nach spaetestens X sekunden wird erster geholt, danach nach wieder spaetestens nach X sekunden der zweite. Damit hat der 2. theoretisch nicht X sondern vll 2X sekunden zeit gehabt ....

d.h. wenn ich im grunde sage: Alle Threads muessen nach 30sekunden fertig sein, scheint mir das nicht zu funktionieren.

Denn hier frag ich nach dem ersten der mir innerhalb von 30sek was gibt. Danach weiss ich, dass es noch weitere Threads gibt und frage wieder nach einem der innerhalb von 30sek was zurueck gibt und und und....
also kann man theoretisch nicht nach 30sek fertig sein sondern bei 2 min oder so...

hoffe das war verstaendlicher ?
 

byte

Top Contributor
OK, Problem erkannt. Hast Du mal probiert, mit ExecutorService#invokeAll(callables, timeout, unit) alle Tasks zu submitten. Dann kannst Du ja so lange die Future-Objekte der Ergebnisliste überwachen, bis der Timeout abgelaufen ist.

Wobei mich jetzt dieser Satz in der Javadoc von invokeAll() etwas irritiert:
Future.isDone() is true for each element of the returned list.

???:L
 
B

bygones

Gast
danke dir... das ist es ;-)

Code:
public class ThreadExecuterTest {

   public static void main( String[] args ) throws Exception {
        MyCallable c = new MyCallable( "1", 1000 );
        MyCallable c1 = new MyCallable( "2", 200 );
        MyCallable c2 = new MyCallable( "3", 4000 );
        MyCallable c3 = new MyCallable( "4", 6000 );
        
        List<Callable<String>> l = new LinkedList<Callable<String>>();
        l.add(c);
        l.add(c1);
        l.add(c2);
        l.add(c3);
        
        ExecutorService service = Executors.newFixedThreadPool(l.size());
        List<Future<String>> ll = service.invokeAll(l, 5, TimeUnit.SECONDS);
        
        for ( Future< String > future : ll ) {
            try {
                System.out.println(future.get());
            }
            catch(CancellationException e) {
                System.out.println("cancelled");
            }
        }
    }

    static class MyCallable implements Callable< String > {
        private final String b;
        private int i;
        MyCallable( String b, int k ) {
            this.b = b;
            i = k;
        }

        public String call() throws Exception {
            Thread.sleep(i);
            return b;
        }
    }
}
das mal nur als ein dummy test programm

das haette ich vorher schonmal so aehnlich....

entweder alle sind schon vor dem timeout fertig - dann wird die schleife durchlaufen und die ergebnisse geholt, oder er wartet X sekundn und laeuft dann durch und hat die nicht fertigen gecancelled.....
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Frage bzgl. Erstellung eines Datenmodells Allgemeine Java-Themen 5
N Frage bzgl. JDK 1.3 Allgemeine Java-Themen 8
C Frage bzgl. der Benennung meiner Anwendung Allgemeine Java-Themen 5
H frage bzgl. übungsaufgabe. Allgemeine Java-Themen 4
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
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11

Ähnliche Java Themen

Neue Themen


Oben