IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Java Discussion :

ExecutorService Producteur/ consomateur


Sujet :

Java

  1. #1
    Membre averti
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Octobre 2011
    Messages
    50
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Octobre 2011
    Messages : 50
    Par défaut ExecutorService Producteur/ consomateur
    Bonjour,
    J'ai suivi un tuto sur le framwork Executor, mais il reste un petit point d'ombre sur le CompletionService.
    Je souhaiterai lancer de nouveaux thread des qu'un future est disponible vie le take() du CompletionService.
    Je ne vois pas du tout comment effectuer cela.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
     
    //...
    	private List<Future<Administre>> futuresAdm = null;
    	private List<Callable<Administre>> taskAdm = null;
    	private List<Future<Administre>> futuresData = null;
    	private List<Callable<Administre>> taskAdmData = null;
    //...
    public void start(){
    		// lancement du pool de recuperation des administres
    		try {
    			// on recupere une liste de nni a traiter pour les ajouter a la liste des taches (thread producteur)
    //			daoInfx = new DaoAdministreGds();
    			daoInfx = new DaoBouchAdministreGds();
    			for (Administre adm : daoInfx.findAll(false)){
    				taskAdm.add(new ImportAdministreCallable(adm));
    			}
    			// declaration de l'executor en pool de thread limité au nombre de cpu disponible sur la machine
    			ExecutorService executorAdm = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
    			ExecutorService executorData = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
    			// declaration du Completion service pour traitement des resultats des que disponibles
    			CompletionService<Administre> completionServiceAdm = new ExecutorCompletionService<>(executorAdm);
    			CompletionService<Administre> completionServiceData = new ExecutorCompletionService<>(executorData);
    			// ajout des taches a traiter a la liste de Futurs<T>
    			for (Callable<Administre> c : taskAdm){
    				futuresAdm.add(completionServiceAdm.submit(c));
    			}
    //...
    voila ce que je souhaiterai faire des qu'un objet future est disponible, mais comment?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    				task = new ImportDataFromAdmCallable(completionServiceAdm.take().get());
    				taskAdmData.add(task);
    				futuresData.add(completionServiceData.submit(task));

  2. #2
    Membre averti
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Octobre 2011
    Messages
    50
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Octobre 2011
    Messages : 50
    Par défaut
    Re bonjour,
    J'ai mis une simple boucle while.
    Seulement, je ne trouve pas de condition pour sortir de la boucle.
    Tous les traitements s’exécutent correctement, mais le programme ne termine jamais.
    J'ai essayé avec la méthode .isTerminated() de L'ExecutorService, mai cela ne semble pas fonctionner.
    Si quelqu'un a un idée...

    pour info :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    while(!executorAdm.isTerminated()){
    	// creation des taches de recuperation des donnés des qu'un adm est créé 
    	task = new ImportDataFromAdmCallable(completionServiceAdm.take().get());
    	taskAdmData.add(task);
    	futuresData.add(completionServiceData.submit(task));
    }

  3. #3
    Membre averti
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Octobre 2011
    Messages
    50
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Octobre 2011
    Messages : 50
    Par défaut
    J'ai trouvé une piste.
    http://www.developpez.net/forums/d61...s/#post3613506

    Cela fonctionne correctement si j'ai 30 administrés a traiter, par contre si je passe a 300 le programme ne s’arrête pas..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    			daoInfx = new DaoBouchAdministreGds(300);
    			taskAdm = new ArrayList<>();
    			for (Administre adm : daoInfx.findAll(false)){
    				taskAdm.add(new ImportAdministreCallable(adm));
    			}
    			// declaration de l'executor en pool de thread limité au nombre de cpu disponible sur la machine
    			ExecutorService executorAdm = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
    			ExecutorService executorData = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
    			if (log.isDebugEnabled()) log.debug(" pour " + Runtime.getRuntime().availableProcessors() + " Threads" );
    			// declaration du Completion service pour traitement des resultats des que disponibles
    			CompletionService<Administre> completionServiceAdm = new ExecutorCompletionService<>(executorAdm);
    			CompletionService<Administre> completionServiceData = new ExecutorCompletionService<>(executorData);
    			// ajout des taches a traiter a la liste de Futurs<T>
    			for (Callable<Administre> c : taskAdm){
    				completionServiceAdm.submit(c);
    			}
    			executorAdm.shutdown();
    			// lancement des threads fils.
    			ImportDataFromAdmCallable task = null;
    			while(!executorAdm.isTerminated()){
    				// creation des taches de recuperation des données des qu'un adm est créé
    				Future<Administre> futAdm = completionServiceAdm.take();
    				task = new ImportDataFromAdmCallable(futAdm.get());
    				completionServiceData.submit(task);
    			}
    			executorData.shutdown();
    			executorData.awaitTermination(120, TimeUnit.SECONDS);
    			log.info ("fin du traitement multiThreads...");
    Merci

Discussions similaires

  1. Réponses: 1
    Dernier message: 15/04/2016, 15h39
  2. Interface graphique et thread producteur-consomateur
    Par fockbliss17 dans le forum C#
    Réponses: 6
    Dernier message: 11/12/2010, 14h10
  3. [ODBC] Probleme de consomateur ODBC avec Oracle
    Par Zaitchev dans le forum Oracle
    Réponses: 3
    Dernier message: 25/02/2006, 09h45
  4. Réponses: 8
    Dernier message: 09/02/2006, 18h51

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo