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

C++ Discussion :

plantage parcours vecteur


Sujet :

C++

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2009
    Messages : 43
    Points : 30
    Points
    30
    Par défaut plantage parcours vecteur
    Bonjour,

    j'ai un problème de platage lors d'un parcour de vecteur. ça ne plante que pour le suivant alors que j'utilise la même logique que pour le précédent. Le message d'erreur est "iterator not dereferencable" lors de l'affichage, je suppose que c'est parce que je sors du vecteur.... Logiquement ça devrait pas vu que je test si l'iterateur est egal à la fin du vecteur.

    .cpp
    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
     
    vector<Perso*>::iterator conteneurp::suivant()
    {
    	if (ipb == dpperso.end())
    		cout<<"Dernier perso!"<<endl;
    	else
    	ipb++;
    	return ipb;
    }
     
    vector<Perso*>::iterator conteneurp::precedent()
    {
    	if (ipb == dpperso.begin())
    		cout<<"Premier perso!"<<endl;
    	else
    	ipb--;
    	return ipb;
    }
    main:


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    vector<Perso*>::iterator ipb; //iterator de travail
    	case '4':
    		system("cls");
    		ipb=cont.suivant();
    		(*ipb)->AfficherPerso();
    		break;
     
    	case '5':
    		system("cls");
    		ipb=cont.precedent();
    		(*ipb)->AfficherPerso();
    		break;
    Merci d'avance.

  2. #2
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 612
    Points : 30 612
    Points
    30 612
    Par défaut
    Salut,

    Le problème, c'est que tu obtiens bel et bien un itérateur valide, mais pointant sur ... rien lorsque tu essaye d'accéder à tab.end() (ou tab est n'importe quelle collection STL)

    Ce que tu dois donc faire, si tu utilise une des collection de la STL comme membre de classe, et que tu souhaite disposer d'un itérateur sur la collection disponible depuis l'extérieur (ce qui n'est, à bien y penser, pas forcément l'idéal ), c'est définir des fonctions membres qui renvoient le résultat de tab.begin() et tab.end() (en version const et / non const selon le cas), et vérifier que l'itérateur que tu as obtenu différent du résultat renvoyé par cette fonction.

    Par exemple:
    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
    class MyClass
    {
     
        typedef std::vector<Perso*> vector;
        public:
            typedef vector::iterator iterator;
            typedef vector::const_itertator const_iterator;
            /*je passe sur les constructeurs ;) */
            iterator begin(){return tab.begin();}
            iterator end(){return tab.end();}
            const_iterator begin() const{return tab.begin();}
            const_iterator end() const{return tab.end();}
            /* les différentes fonctions qui vont bien */
        private:
            vector tab;
    };
    (tu n'as même pas à t'inquiéter de permettre le passage à l'élément suivant ou à l'élément précédent, vu que ce sont les itérateurs qui s'en chargent)

    Tu pourra utiliser ces fonctions sous une forme proche de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    /* soit mc est un objet de type MaClass */ 
    for(MaClass::iterator it=mc.begin();it!=mc.end();++it)
    {
        /* tout ce qui doit être fait */
    }
    /* ou, la version "constante" */
    for(MaClass::const_iterator it=mc.begin();it!=mc.end();++it)
    {
        /* tout ce qui doit être fait */
    }
    /* et tu pourra même envisager d'utiliser les fonctions qui manipulent des
     * intervalles
     */
    MaClass::const_iterator result=std::find_if(mc.begin(),mc.end(),predicat);
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2009
    Messages : 43
    Points : 30
    Points
    30
    Par défaut
    Excellent! Merci beaucoup ça fonctionne

  4. #4
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 612
    Points : 30 612
    Points
    30 612
    Par défaut
    Au passage, et bien que cela n'ait rien à voir, méfie toi des collections qui manipulent des pointeurs "classiques" sur des objets...

    C'est un gros tas de pièges dans lequel tu risque de te retrouver avec des fuites mémoire, des double libérations de la mémoire ou des pointeurs invalides en pagaille
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

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

Discussions similaires

  1. Optimiser le temps de parcours d'un vecteur
    Par rtsKyo dans le forum Débuter avec Java
    Réponses: 4
    Dernier message: 15/03/2012, 11h55
  2. Problème de parcours d'un vecteur
    Par teckto dans le forum MATLAB
    Réponses: 3
    Dernier message: 30/04/2008, 22h11
  3. Réponses: 8
    Dernier message: 29/01/2008, 22h22
  4. [STL] parcours d'un vecteur
    Par ZaaN dans le forum SL & STL
    Réponses: 7
    Dernier message: 26/06/2007, 14h48
  5. [Débutante] Problème de parcours d'un vecteur
    Par sab_etudianteBTS dans le forum Langage
    Réponses: 4
    Dernier message: 20/05/2007, 14h29

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