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

Langage Java Discussion :

ConcurrentModificationException = problème d'iteration?


Sujet :

Langage Java

  1. #1
    Membre éclairé Avatar de grabriel
    Inscrit en
    Septembre 2006
    Messages
    946
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 946
    Par défaut ConcurrentModificationException = problème d'iteration?
    Bonjour,

    J'ai une erreur : ConcurrentModificationException j'ai cherché et trouvé les explications et des solution mais aucune ne résout mon problème. A ce que j'ai compris, cette exception est levé quand on modifie une collection dans une boucle qui la liste puisque l'iterateur ouvre la collection en lecture seule.

    Donc voici mon bout de code modifié d'après les différentes solutions que j'ai trouvé ici et là :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    newlistTitre_Compte.addAll(listTitre_Compte);
    		Iterator<Titre_Compte> iterator = listTitre_Compte.iterator();
     
    		while(iterator.hasNext()){
                Titre_Compte titre = iterator.next();
                ActionUtils.echo(titre);
                newlistTitre_Compte = recherchePere(titre,listTitre_Compte);
            }
    et

    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
    private List<Titre_Compte> recherchePere(Titre_Compte titre,List<Titre_Compte> listTitre_Compte){
    		int pere = titre.getPere();
    		Titre_Compte titrePere = null;
     
    		try {
    			titrePere = daoTitre_Compte.getTitre_CompteById(pere);
    		} catch (BusinessException be) {
    			Erreurs.Warning(be);
    		}
    		List<Titre_Compte> newlistTitre_Compte = new ArrayList<Titre_Compte>();
     
    		//si pas deja le rajouter et rechercher son pere
    		if (!listTitre_Compte.contains(titrePere) && titrePere.getidTic() != 0){
    			listTitre_Compte.add(titrePere);
    			ActionUtils.echo("ne contiens pas : " + titrePere);
    			newlistTitre_Compte = recherchePere(titrePere,listTitre_Compte);
    		}
    		return newlistTitre_Compte;
    	}

    Mon printstack :
    Exception in thread "AWT-EventQueue-0" java.util.ConcurrentModificationException
    at java.util.AbstractList$Itr.checkForComodification(Unknown Source)
    at java.util.AbstractList$Itr.next(Unknown Source)
    at com.domaine.ihm.ActionBanqueDepense.creePanelRapide(ActionBanqueDepense.java:669)
    at com.domaine.ihm.ActionBanqueDepense.creePanelSaisie(ActionBanqueDepense.java:195)
    at com.domaine.ihm.ActionBanqueDepense.actionPerformed(ActionBanqueDepense.java:117)
    at javax.swing.AbstractButton.fireActionPerformed(Unknown Source)
    La ligne 669 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Titre_Compte titre = iterator.next();
    Même en passant par une autre liste le message d'erreur est toujours là. Voila j'espère que vous avez tous les éléments...

    Merci d'avance!!

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Février 2007
    Messages
    572
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Février 2007
    Messages : 572
    Par défaut
    Ben t'as toujours une modification de la liste pendant que tu utilises l'iterator

    Voila la boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    while(iterator.hasNext()){
                Titre_Compte titre = iterator.next();
                ActionUtils.echo(titre);
                newlistTitre_Compte = recherchePere(titre,listTitre_Compte);
    }
    Et voila dans recherchePere(titre,listTitre_Compte); la ligne qui modifie la liste
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    listTitre_Compte.add(titrePere);

  3. #3
    Membre éclairé Avatar de grabriel
    Inscrit en
    Septembre 2006
    Messages
    946
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 946
    Par défaut
    euhhhh j'ai dû rater un épisode si j'ai rajouter l'iterator c'est justement pour ne plus avoir le message d'erreur et pouvoir modifier ma liste....

    Peut etre que mon raisonnement n'est pas bon en faite ce que je suis en train de faire c'est un arbre je récupère des éléments mais certains sont orphelins d'ou la recursivité de recherchepere qui va compléter la liste pour pas qu'il y ait d'orphelins... Donc je suis bien obligé de modifier la liste pour pouvoir la compléter. Sinon est-ce qu'il y a une autre méthode pour mon problème.

    MERCI!!

    Sangahon

  4. #4
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,


    Tu dois utiliser une liste en copie pour l'itération, car si tu modifies la liste pendant que tu itères dessus tu risque d'avoir des incohérences (sauter ou répéter des éléments).

    Apparemment ton code fait déjà une copie (newlistTitre_Compte) mais tu ne l'utilises pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	newlistTitre_Compte.addAll(listTitre_Compte);
    	// Il faut utiliser newlistTitre_Compte pour l'itérateur 
    	Iterator<Titre_Compte> iterator = newlistTitre_Compte.iterator();
    	while(iterator.hasNext()){
    		Titre_Compte titre = iterator.next();
    		ActionUtils.echo(titre);
    		newlistTitre_Compte = recherchePere(titre,listTitre_Compte);
    	}
    a++

    PS : les underscores dans les noms de variables, ce n'est pas super lisible et cela me rappelle le C

Discussions similaires

  1. Problème balise iterate avec la classe HashSet
    Par kokumbo dans le forum Struts 1
    Réponses: 8
    Dernier message: 07/11/2007, 15h43
  2. Problème Logic Iterate
    Par lalyly dans le forum Struts 1
    Réponses: 9
    Dernier message: 28/05/2007, 15h14
  3. Problème d'Iterator
    Par ceraud dans le forum Langage
    Réponses: 6
    Dernier message: 17/02/2007, 19h13
  4. problème avec iterator
    Par akrobat dans le forum C++
    Réponses: 3
    Dernier message: 24/11/2005, 17h23
  5. [struts][iterate] problème logic:iterate avec un Vector
    Par jaimepasteevy dans le forum Struts 1
    Réponses: 9
    Dernier message: 31/03/2004, 18h05

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