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

Concurrence et multi-thread Java Discussion :

Thread et ordre d'insertion dans un arrayList


Sujet :

Concurrence et multi-thread Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 99
    Par défaut Thread et ordre d'insertion dans un arrayList
    Salut, j'ai une boucle qui itère la récupération un objet d'une méthode pour l'insérer dans un ArrayList :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
       for (int i = 0; i < this.nbChannel; i++) 
    	{
            homoDistances .add(computeOneChannelHomoDistances(i));
    	}
    L'ordre d'insertion dans l'ArrayList est important. Je souhaite paralléliser cela en lançant chaque traitement getMonObject de la boucle dans un thread. Dans ce cas l'ordre d'insertion dans l'arraylist monArray se fera en fonction de l'ordre de fin de traitement de getMonObject(i) de chaque trhead donc pas toujours le même et imprévisible.

    Comment faire pour insérer "dans le bon ordre" (ordre de la boucle) ces objets récupérés depuis des threads qui finissent un peu quand ils veulent ?

    Pour l'instant je fais ça en stockant mes objets dans un tableau que je parcoure après avoir attendu la fin de tous les threads (latcher). J'utilise alors le tableau comme source pour insérer dans le bon ordre les objets dans mon ArrayList.

    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    final FishDistanceSet[] homoDistancesTab = new FishDistanceSet[this.nbChannel];
    final CountDownLatch latcher = new CountDownLatch(nbChannel);
     
    //Homologous distances
    for (int i = 0; i < this.nbChannel; i++) 
    	{
    	final int j;
    	j=i;
    	Thread th = new Thread(new Runnable()
    	{
    		public void run()
    		      {
                           homoDistancesTab[j]=computeOneChannelHomoDistances(j);
                           latcher.countDown();
                           logInfo("channel " + j + " homodistances processed");
                           }
    		}, "computing all channel homodistances");
     
    		th.start();
     
    		}
     
    	// lets wait all channels are processed
    	try
    	{
    	logInfo("waiting all channels homodistances are processed ...");
    	latcher.await();
    	logInfo("All channels homodistances processed");
     
    	} catch (InterruptedException e)
    	{
    	e.printStackTrace();
    	}
     
    	homoDistances = new ArrayList<FishDistanceSet>();	
    	for (int i = 0; i < this.nbChannel; i++) 
    		{
    		homoDistances.add(homoDistancesTab[i]);	
    		}

    Ça marche mais il me semble qu'il doit y avoir plus simple non ?
    PS : j'ai toujours du mal avec la visibilité des variables depuis un thread, le mot clé final me pose souvent des problèmes ..

    merci pour vos suggestions

  2. #2
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    bonjour,

    Une solution est de pré-remplir ton ArrayList et ensuite tu utilises la méthode set() pour mettre les infos au bon endroit.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    		ArrayList<String> lst = new ArrayList<String>(3);
    		for (int i = 0; i < 3; i++) {
    			lst.add(null);
    		}
     
    		lst.set(2, "dernier");
    		lst.set(0, "premier");
    		lst.set(1, "centre");
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 99
    Par défaut
    Merci !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Problème avec l'insertion dans une ArrayList
    Par LoveIinfo dans le forum Collection et Stream
    Réponses: 7
    Dernier message: 08/06/2011, 22h29
  2. Insertion dans une Arraylist
    Par 4rocky4 dans le forum Collection et Stream
    Réponses: 1
    Dernier message: 07/05/2011, 15h03
  3. Insertion dans un fichier trié par ordre croissant
    Par darkterreur dans le forum Langage
    Réponses: 14
    Dernier message: 20/09/2009, 19h39
  4. Réponses: 3
    Dernier message: 29/08/2007, 20h43
  5. Syntaxe tableaux dans ordre SQL INSERT
    Par lio33 dans le forum SQL
    Réponses: 6
    Dernier message: 19/10/2005, 17h07

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