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 :

Problème avec une itération


Sujet :

Java

  1. #1
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Points : 28
    Points
    28
    Par défaut Problème avec une itération
    Bonjour,

    J'ai un problème avec le code suivant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public T prochainElement() {
            T element = null;
            if (iterateur.hasNext()) {
                element = iterateur.next(); // c est ici ou je me plante 
            }
            return element;
    }
    iterateur c'est un attribut de la classe listImpl que j'utilise pour parcourir mes listes.

    J'ai utilisé iterateur.next() dans d'autres méthodes et ça fonctionne mais ici ça me donne un exception java.util.ConcurrentModificationException

    Quelqu'un saurait-il m'expliquer d'où vient le problème ?

    Merci d'avance pour votre aide.

  2. #2
    Membre averti Avatar de welcome_59
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2007
    Messages
    203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2007
    Messages : 203
    Points : 352
    Points
    352
    Par défaut
    java.util.ConcurrentModificationException survient en général lorsque tu essaies de modifier ta liste pendant son parcours (ou l'inverse).

    Le code que tu as posté est insuffisant pour te dire ce qui se passe précisément dans ton cas, idem pour les solutions.

    Poste le code de la classe, celui dans lequel tu l'utilises et la trace complète de l'exception.
    SCJP 5 | CAPM

  3. #3
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Points : 28
    Points
    28
    Par défaut le code en entier
    Citation Envoyé par welcome_59 Voir le message
    java.util.ConcurrentModificationException survient en général lorsque tu essaies de modifier ta liste pendant son parcours (ou l'inverse).

    Le code que tu as posté est insuffisant pour te dire ce qui se passe précisément dans ton cas, idem pour les solutions.

    Poste le code de la classe, celui dans lequel tu l'utilises et la trace complète de l'exception.
    Voici mon code. Ce que j'essaye de faire c'est d'ajouter une liste sur une autre liste qui n'accepte pas des doublons.
    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
    public class ListeAdtArraylistImpl<T> implements ListeAdt<T> {
     
        private ArrayList<T> listeAdt;
        private Iterator<T> iterateur;
     
        public ListeAdtArraylistImpl() {
            listeAdt = new ArrayList<T>();
            iterateur = listeAdt.iterator();
            }
        public T[] ajouter(ListeAdt<T> liste) {
            ArrayList<T> listElementNonAjoute = new ArrayList<T>();
            while (liste.existeProchainElement() && liste != null) {
                T elementCourant = liste.prochainElement();
                if (liste.estElements(elementCourant)) {
                    ajouter(elementCourant);
                } else {
                    listElementNonAjoute.add(elementCourant);
                }
            }
            return (T[]) listElementNonAjoute.toArray();
        }
     
        public boolean estElements(T element) {
            for (T elementExiste : listeAdt) {
                if (elementExiste.equals(element)) {
                    return true;
                }
            }
            return false;
        }
    public T prochainElement() {
    T element = null;
    if (iterateur.hasNext()) {
    element = iterateur.next(); // c est ici ou je me plante 
    }
    return element;
    }

  4. #4
    Membre averti Avatar de welcome_59
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2007
    Messages
    203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2007
    Messages : 203
    Points : 352
    Points
    352
    Par défaut
    Ce que j'essaye de faire c'est d'ajouter une liste sur une autre liste qui n'accepte pas des doublons
    Pourquoi pas simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Set<T> collectionSansDoublons = new HashSet<T>();
    ... // Tu peux utiliser ton set
    List<T> liste = new ArrayList<T>();
    ... //Tu peux utiliser ta liste (la remplir par exemple)
    Et tu peux ajouter des éléments à ton set
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    collectionSansDoublons.addAll(liste); //pour ajouter tous les éléments de la liste
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    collectionSansDoublons.add(liste.get(0)); // pour ajouter un seul élément de la liste
    Les Set sont des collections qui n'acceptent pas les doublons et la gestion du problème est implémentée en "natif" dans l'API. C'est plus sûr et plus rapide.
    SCJP 5 | CAPM

  5. #5
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Points : 28
    Points
    28
    Par défaut
    Citation Envoyé par welcome_59 Voir le message
    Pourquoi pas simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Set<T> collectionSansDoublons = new HashSet<T>();
    ... // Tu peux utiliser ton set
    List<T> liste = new ArrayList<T>();
    ... //Tu peux utiliser ta liste (la remplir par exemple)
    Et tu peux ajouter des éléments à ton set
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    collectionSansDoublons.addAll(liste); //pour ajouter tous les éléments de la liste
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    collectionSansDoublons.add(liste.get(0)); // pour ajouter un seul élément de la liste
    Les Set sont des collections qui n'acceptent pas les doublons et la gestion du problème est implémentée en "natif" dans l'API. C'est plus sûr et plus rapide.
    merci pour la proposition. mais je n'ai pas le droit d'utiliser autre structure que ArrayList, aussi je dois faire usage aux méthodes que moi même j'ai développer c-à-d estElement(T element); prochainElement(); ajouter(T element); pour développer la méthode ajouter(listeAdt<T> liste);
    si vous avez une autre piste ça va beaucoup m'aider
    Merci d'avance

  6. #6
    Modérateur
    Avatar de wax78
    Homme Profil pro
    Chef programmeur
    Inscrit en
    Août 2006
    Messages
    4 075
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chef programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 4 075
    Points : 7 981
    Points
    7 981
    Par défaut
    Tu utilises 2 thread qui jouent avec ton arrayList ? (Ce que je suppose Welcome voulait dire dans son premier message, on ne voit pas "qui" joue avec la liste)

    Si oui, as tu bien crée ta liste avec ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    List list = Collections.synchronizedList(new ArrayList(...));
    (Les "ça ne marche pas", même écrits sans faute(s), vous porteront discrédit ad vitam æternam et malheur pendant 7 ans)

    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Points : 28
    Points
    28
    Par défaut en fin solution trouver
    voici la solution que j ai pu trouver grâce a vos éclaircissement, si vous voyez une façon plus optimiser pour faire bienvenue a toute autres suggestions :
    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
     
    public class ListeAdtArraylistImpl<T> implements ListeAdt<T> {
     
    	/**
             * Liste des éléments de la pile.
             */
    	private ArrayList<T> listeAdt;
    	private Iterator<T> iterateur;
     
    	public ListeAdtArraylistImpl() {
    		listeAdt = new ArrayList<T>();
    		iterateur = listeAdt.iterator();
    	}
     
    public T[] ajouter(ListeAdt<T> liste) {
    		ArrayList<T> listeElementNonAjoute = new ArrayList<T>();
    		ArrayList<T> listeElementAjoute = new ArrayList<T>();
     
    		for (T element : listeAdt) {
    			if (liste.estElements(element)) {
    				listeElementNonAjoute.add(element);
    			} else {
    				listeElementAjoute.add(element);
    			}
    		}
    		for (T t : listeElementAjoute) {
    			liste.ajouter(t);
    		}
    		return (T[]) listeElementNonAjoute.toArray();
     
    	}
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public T prochainElement() {
    		return listeAdt.iterator().next();
    	}
    je l'ai tester est ça marche, pour si quelqu'un trouveras un jour le même problème au moins ça va donner une piste.

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

Discussions similaires

  1. Problème avec une itération
    Par mahdiraddadi dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 29/06/2012, 20h07
  2. [JBOSS] [Struts] Problème avec une application
    Par Tiercel dans le forum Wildfly/JBoss
    Réponses: 5
    Dernier message: 13/07/2004, 13h50
  3. Problème avec une instruction OUTER /Postgres
    Par Volcomix dans le forum Langage SQL
    Réponses: 14
    Dernier message: 21/04/2004, 16h56
  4. problème avec une requête imbriquée
    Par jaimepasteevy dans le forum Langage SQL
    Réponses: 13
    Dernier message: 05/12/2003, 10h29
  5. Problème avec une procédure stockée
    Par in dans le forum Langage SQL
    Réponses: 4
    Dernier message: 27/05/2003, 15h33

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