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 :

Parcours, et libération d'une liste de pointeurs avec un iterator


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    139
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 139
    Par défaut Parcours, et libération d'une liste de pointeurs avec un iterator
    Bonjour,

    Je cherche à explorer une liste de pointeurs. Je veux tester les objets pointés sur l'un de leurs critères, et dès que le test est vérifié, je souhaite enlever le pointeur de ma liste et libérer ce pointeur. Après une libération, je ne suis pas obligé de continuer mon parcours (pour vérifier que d'autres objets pointés vérifient la condition également).

    Voici mon code (qui ne marche évidemment pas) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    for(std::list<Objet *>::iterator itObjet = getListeObjets()->begin(); 
    			itObjet != getListeObjets()->end(); itObjet++)
    		{
    			if( itObjet->getCritere() == CONDITION)
    			{
    				getListeObjets()->erase(*itObjet);
    				delete *itObjet;
    			}
    		}

  2. #2
    Membre Expert

    Inscrit en
    Mai 2008
    Messages
    1 014
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 1 014
    Par défaut
    Bonjour,
    Citation Envoyé par K-you
    Voici mon code (qui ne marche évidemment pas) :
    ...
    Non, en effet, car l'itérateur est invalide après l'erase.
    Il faut d'abord supprimer l'objet.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    for(std::list<Objet*>::iterator itObjet = getListeObjets()->begin(); 
    			itObjet != getListeObjets()->end(); itObjet++)
    {
       if( itObjet->getCritere() == CONDITION)
       {
          delete *itObjet;
          getListeObjets()->erase(itObjet);
          break;
       }
    }

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    139
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 139
    Par défaut
    Mais alors, ça veut dire qu'on supprimer ce sur quoi pointe l'itérateur (donc l'objet alloué dans la mémoire), et seulement ensuite, on appelle une fonction qui doit rechercher cet objet dans la liste et le supprimer ? Cette appel ne devrait pas être en mesure de retrouver l'objet puisqu'il n'existe plus ?

  4. #4
    Membre Expert

    Inscrit en
    Mai 2008
    Messages
    1 014
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 1 014
    Par défaut
    Citation Envoyé par K-you Voir le message
    et seulement ensuite, on appelle une fonction qui doit rechercher cet objet dans la liste et le supprimer ?
    La fonction membre erase de std::list ne prend pas en paramètre un objet mais un itérateur.

  5. #5
    Membre émérite

    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    717
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 717
    Par défaut
    Donc oui, pas de problème à ce niveau là, par contre il y a un problème après parce qu'on incrémente un itérateur qui a été invalidé par la suppression.

    Une façon correcte de procéder est dans la FAQ !

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2010
    Messages
    139
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 139
    Par défaut
    Ok, merci je comprend mieux. Le erase de la FAQ est, en effet meilleur.

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

Discussions similaires

  1. Trier une liste de pointeur de class
    Par lolaalol dans le forum C++
    Réponses: 10
    Dernier message: 26/01/2013, 03h42
  2. Réponses: 2
    Dernier message: 08/09/2011, 09h07
  3. trier une liste de pointeurs sur personne
    Par italiasky dans le forum SL & STL
    Réponses: 5
    Dernier message: 10/11/2007, 14h53
  4. [STL] Clear une liste de pointeurs
    Par mambo dans le forum SL & STL
    Réponses: 2
    Dernier message: 21/03/2007, 16h07
  5. fuite de memoire dans une liste de pointeur sur composant
    Par Nicolos_A dans le forum Composants VCL
    Réponses: 2
    Dernier message: 16/12/2004, 08h46

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