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

SL & STL C++ Discussion :

Iterateur d'un vector


Sujet :

SL & STL C++

  1. #1
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut Iterateur d'un vector
    Bonjour à tous,

    Dans un de mes programmes, je travaille avec le conteneur vector. Je débute avec les conteneurs, donc j'y vais pas à pas, à la lumière des trucs que je peux lire un peu partout.
    Là j'ai un petit pépin. Je souhaite utiliser l'outil itérateur proposé par la classe vector, en lieu et place d'un itérateur manuel.
    A la base ma fonction ressemblait a ca: (sachant que mon vecteur s'appele "MyPeople" et qu'il est composé d'éléments "people")
    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
    int NumberOfPeople = MyPeople.size();
    int detect;
    if (MyPeople.empty())
    {
       Fonction1();
    }
    else
    {
       for (int i=0;i<NumberOfPeople;++i)
       {
          detect = Fonction2(MyPeople.at(i));	
          if (detect==0)		
          {
             Fonction3(MyPeople.at(i));   
          }
       }
       Fonction4();	
    }
    déromais, mon code est le suivant:
    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
    int NumberOfPeople = MyPeople.size();
    vector<people>::iterator MyIte;
    int detect;
    if (MyPeople.empty())
    {
       Fonction1();
    }
    else
    {
       for (MyIte=MyPeople.begin();MyIte!=MyPeople.end();++MyIte)
       {
          detect = Fonction2(*MyIte);	
          if (detect==0)		
          {
             Fonction3(*MyIte);   
          }
       }
       Fonction4();	
    }
    Mais ce "nouveau" code me donne de temps en temps un message d'erreur:

    Le debogueur me pointe alors sur ce fichier dbghook.c:


    Merci d'avance pour votre aide (et conseils )

  2. #2
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    Tu dois vraissemblablement avoir d'autres soucis.
    C'est quelle fonction qui pose problème ?

  3. #3
    Membre confirmé Avatar de Sachiel31
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    121
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 121
    Par défaut
    Bonjour,

    Pourquoi as tu toujours un i dans la condition de ton for???

    Je ne pense pas que se soit la principale erreur mais ce qui est sure, c'est que ca ne doit pas passer

  4. #4
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut
    Citation Envoyé par Sachiel31
    Bonjour,

    Pourquoi as tu toujours un i dans la condition de ton for???

    Je ne pense pas que se soit la principale erreur mais ce qui est sure, c'est que ca ne doit pas passer
    C'etait juste une erreur d'inatention et de copié/colle lors de l'écriture de mon message Je corrige...

  5. #5
    Membre Expert
    Avatar de Eusebe
    Inscrit en
    Mars 2006
    Messages
    1 992
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 992
    Par défaut
    Citation Envoyé par BNS
    C'etait juste une erreur d'inatention et de copié/colle lors de l'écriture de mon message Je corrige...
    Pendant que tu y es, fermes l'accolade du corps de ton for

  6. #6
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut
    Citation Envoyé par Miles
    Tu dois vraissemblablement avoir d'autres soucis.
    C'est quelle fonction qui pose problème ?
    Ben le truc c'est que la première version (avec les itérateurs manuels) fonctionne... Donc je pense que je dois mal utiliser l'outil Itérateur fourni par la classe vector. Ou bien, est-ce que je l'utilise correctement?

  7. #7
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    Au niveau de l'itérateur, c'est bon, je pencherai plus sur un autre problème, mais vu ton code, on ne peut pas dire quoi.

  8. #8
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut
    merci, donc je suis sur la mauvaise piste. Je vais chercher l'erreur autre part alors... si jamais je ne la trouve pas, je poste mon code plus en détail ici.

  9. #9
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut
    Au passage, c'est quoi le plus judicieux et le plus propre d'utilisation entre l'itérateur manuel et celui donné dans la classe?

  10. #10
    Membre chevronné
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 464
    Par défaut
    Citation Envoyé par BNS
    Au passage, c'est quoi le plus judicieux et le plus propre d'utilisation entre l'itérateur manuel et celui donné dans la classe?
    Les itérations par indices, à la manière des tableaux C, sont à priori plus lentes qu'en passant par un itérateur.

  11. #11
    Membre confirmé Avatar de Sachiel31
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    121
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 121
    Par défaut
    Citation Envoyé par BNS
    Au passage, c'est quoi le plus judicieux et le plus propre d'utilisation entre l'itérateur manuel et celui donné dans la classe?
    Il est plus judicieux d'utiliser les itérateurs de Vector (que les itérateurs manuels) car c'est plus propres et plus rapide.

  12. #12
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Par défaut
    Au pif, est-ce que tes fonctions touchent au tableau en question ?

  13. #13
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut
    Ouais, elles vont scruter dans le vecteur...

  14. #14
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Par défaut
    Juste scruter ? Aucune manipulation qui pourrait invalider les itérateurs ?

  15. #15
    Expert confirmé
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 296
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 296
    Par défaut
    Citation Envoyé par Sachiel31
    Il est plus judicieux d'utiliser les itérateurs de Vector (que les itérateurs manuels) car c'est plus propres et plus rapide.
    s/itérateur manuel/indices
    Cela dépend, ce n'est pas nécessaire sur un vecteur. Parfois il y a l'avantage pour l'un, parfois pour l'autre, parfois il n'y a aucune différence.
    Ce qui est sûr, c'est qu'utiliser at() plutôt que l'opérateur [] ralentit. Recalculer la taille dans la boucle aussi.

    PS: toujours préférer déclarer la variable à l'endroit où l'on est capable de l'initialiser à se valeur nominale. Pas avant.
    Soit, en supposant qu'il n'y ait aucune invalidation des itérateurs:
    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
     
    if (MyPeople.empty()) {
       Fonction1();
    } else {
       for (vector<people>::iterator b=MyPeople.begin(), e=MyPeople.end()
          ; b !=e 
          ; ++b)
       {
          const int detect = Fonction2(*b);	
          if (detect==0)		
          {
             Fonction3(*b);   
          }
       }
       Fonction4();	
    }
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

  16. #16
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut
    Merci pour vos coups de main, apres une bonne soirée de repos, je me remet au travail pour trouver d'ou vient mon erreur.
    Juste scruter ? Aucune manipulation qui pourrait invalider les itérateurs ?
    Si, je les manipule aussi. L'erreur pourrait donc venir de là? Par exemple une des opérations possible et de supprimer un élément. Est-ce que ca invalide alors l'itérateur (comme la place des éléments à changer?) ---> en considérant un vecteur de 5 éléments, je peux très bien être amené à supprimer le 3ème en milieu de boucle.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    const int detect = Fonction2(*b);
    Tant que j'y suis... Quel est l'avantage ici d'utiliser const int, et non tout simplement int? Gain de temps?

  17. #17
    Membre Expert
    Avatar de Eusebe
    Inscrit en
    Mars 2006
    Messages
    1 992
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 992
    Par défaut
    Citation Envoyé par BNS
    Si, je les manipule aussi. L'erreur pourrait donc venir de là? Par exemple une des opérations possible et de supprimer un élément. Est-ce que ca invalide alors l'itérateur (comme la place des éléments à changer?) ---> en considérant un vecteur de 5 éléments, je peux très bien être amené à supprimer le 3ème en milieu de boucle.
    Oui, si tu supprimes un élément du tableau, ton itérateur n'est plus valide.
    Voir par exemple http://c.developpez.com/faq/cpp/?pag...ssion_elements

  18. #18
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    Mais en même temps, il ne supprime pas l'élément dans le vecteur puisqu'il ne passe pas l'itérateur !

    const int, ça sert à rien. const std::vector<>, ça sert à peut de choses, c'est plus indicatif pour toi qu'autre chose, const std::vector<>&, c'est utile, puisque tu n'as pas de recopie, mais c'est presque tout.

  19. #19
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Par défaut
    en considérant un vecteur de 5 éléments, je peux très bien être amené à supprimer le 3ème en milieu de boucle
    Donc en fin de compte l'utilisation d'indices était bien la meilleure solution.

  20. #20
    BNS
    BNS est déconnecté
    Membre confirmé
    Inscrit en
    Juin 2005
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 129
    Par défaut
    Concrètement et simplement ca voudrait dire ca (?):
    Considérons un vecteur e composé de 5 éléments e={0, 0, 1, 0, 0}. Je veux supprimer proprement le seul élément non nul. Je peux donc faire ca:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    int i = 0 ;
    while ( i != e.end() )
    {
       if ( e.at(i) != 0 ) e.erase(i);
       else ++i;
    }
    Le resultat final sera alors e = {0,0,0,0} sans bug entre temps?

Discussions similaires

  1. Vector et Iterateurs
    Par miller31 dans le forum Général Java
    Réponses: 2
    Dernier message: 09/04/2015, 08h24
  2. STL/vector : conversion indice : "int" en iterateur
    Par sebkramm dans le forum SL & STL
    Réponses: 7
    Dernier message: 29/09/2007, 14h06
  3. Iterateur sur pointeur de vector
    Par Pragmateek dans le forum SL & STL
    Réponses: 9
    Dernier message: 13/05/2006, 13h50
  4. "vector" provoque "syntax error", malgré
    Par seenkay dans le forum Autres éditeurs
    Réponses: 5
    Dernier message: 24/08/2003, 03h21
  5. Réponses: 2
    Dernier message: 11/07/2003, 18h24

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