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 :

Choix d'un conteneur


Sujet :

C++

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    577
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 577
    Par défaut Choix d'un conteneur
    Bonjour,

    je dois choisir un conteneur (de strings) permettant de réaliser une FIFO.
    Les opérations que je devrais réaliser sont les suivantes :
    - ajout d'un élément string (push)
    - récup l'élément le + vieux (front) et le vider (pop)
    - tester si vide
    - vider

    Donc je me tourne vers std::queue<std::string>

    Qu'e pensez-vous ?

    Ce qui me gêne c'est que la std::queue :
    - n'a pas de fonction "clear" (tout supprimer)
    - n'a pas de fonction qui récupère un élément et qui le supprime.

    @+

  2. #2
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Par défaut
    Citation Envoyé par olive_le_malin
    Ce qui me gêne c'est que la std::queue :
    - n'a pas de fonction "clear" (tout supprimer)
    Si tu veux ça, ce n'est pas très difficile d'utiliser directement std::list ou std::deque.

    Citation Envoyé par olive_le_malin
    - n'a pas de fonction qui récupère un élément et qui le supprime.
    C'est voulu. Implémenter une telle fonction qui réponde aux contraintes d'exception safety voulues pour la STL n'est pas possible. Il y avait un article de Sutter sur le sujet, mais le lien a l'air mort. http://www.awlonline.com/cseng/meyer...E/SU_FRAME.HTM
    Un autre lien, moins détaillé, mais intéressant : http://www.boost.org/more/generic_exception_safety.html
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    577
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 577
    Par défaut
    Bonsoir,

    Citation Envoyé par JolyLoic
    Si tu veux ça, ce n'est pas très difficile d'utiliser directement std::list ou std::deque.
    oui bien sûr ... mais du coup le conteneur choisi est "moins dédié".
    Pour une fois, je voulais réfléchir au conteneur le + approprié et le + parlant pour mes besoins.

    bon sinon je peux toujours faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    while(!q.empty())
     q.pop();

    J'ai aussi vu ce lien qui donne une justification sur le front() + pop() :
    http://www.sgi.com/tech/stl/queue.html

  4. #4
    Expert confirmé
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 287
    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 287
    Par défaut
    C'est affectable et default-constructible. Donc, le clear devrait être immédiat si je ne m'abuse.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    laQueue = TonTypeQueue();
    Pour l'exception-safety de la fonction pop, Sutter en parle dans XC++ dans mes souvenirs. J'imagine que l'on doit retrouver l'article original sur GOTW.
    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...

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    577
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 577
    Par défaut
    Bonsoir,
    Citation Envoyé par Luc Hermitte
    C'est affectable et default-constructible. Donc, le clear devrait être immédiat si je ne m'abuse.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    laQueue = TonTypeQueue();
    Je ne comprends pas ce que tu veux dire ... "clear" n'est pas une méthode de std::queue ...

    Bonne nuit !

  6. #6
    Expert confirmé
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 287
    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 287
    Par défaut
    Non, mais c'est très vite implémenté sans passer par une boucle.
    Un entier que tu veux passer à 0, tu ne le décrémentes pas. Tu lui affectes (assignable) directement 0 (default-constructible). Là, c'est pareil.
    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...

  7. #7
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Par défaut
    Pris d'un doute, j'ai jeté un rapide coup d'oeil à la norme, et je n'ai rien vu qui concerne l'affectation d'une std::queue. Juste un constructeur avec le type de séquence sous-jacent en paramètre.
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  8. #8
    Expert confirmé
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 287
    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 287
    Par défaut
    En effet.
    Le standard et la doc de SGI (que j'avais suivie avant de répondre) divergent ici.
    Ceci dit, le standard ne semble pas interdire explicitement les deux opérations de recopie. Ce qui tend à impliquer le support de la même sémantique de copie que celle du type conteneur -- par une sorte de transitivité. Enfin, c'est ce que je comprends en tout cas.
    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...

  9. #9
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    577
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 577
    Par défaut
    Citation Envoyé par JolyLoic
    Pris d'un doute, j'ai jeté un rapide coup d'oeil à la norme, et je n'ai rien vu qui concerne l'affectation d'une std::queue. Juste un constructeur avec le type de séquence sous-jacent en paramètre.
    .
    Oui c'est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    template<class T,
        class Cont = deque<T> >
    donc pour moi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    std::queue< std::string, std::deque<std::string> >

    Citation Envoyé par Luc Hermitte
    Non, mais c'est très vite implémenté sans passer par une boucle.
    Un entier que tu veux passer à 0, tu ne le décrémentes pas. Tu lui affectes (assignable) directement 0 (default-constructible). Là, c'est pareil.
    OK, je comprends mieux !!
    Je donc vais essayer de lui assigner ... une queue vide.

    Merci pour vos réponses, qui plus est, tardives !
    @+

  10. #10
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Par défaut
    Citation Envoyé par Luc Hermitte
    En effet.
    Le standard et la doc de SGI (que j'avais suivie avant de répondre) divergent ici.
    Ceci dit, le standard ne semble pas interdire explicitement les deux opérations de recopie. Ce qui tend à impliquer le support de la même sémantique de copie que celle du type conteneur -- par une sorte de transitivité. Enfin, c'est ce que je comprends en tout cas.
    <Mode Chippotage="true">
    Citation Envoyé par Le standard
    Descriptions of class member functions follow the order (as appropriate):147)
    — Constructor(s) and destructor
    — Copying & assignment functions
    — Comparison functions
    — Modifier functions
    — Observer functions
    — Operators and other nonmember functions

    147/ To save space, items that do not apply to a class are omitted. For example, if a class does not specify any comparison functions, there will be no ‘‘Comparison functions’’ subclause
    J'en déduit qu'en standardese, et contrairement au C++, s'il n'y a rien de spécifié sur les Copying & assignment functions, c'est qu'il n'y a pas de Copying & assignment functions. Ca vaudrait le coup de vérifier sur fr.comp.lang.c++...

    Ensuite, l'autre question que je me pose, c'est que les containers sont assignables. std::queue est un container adaptor. Mais un container adaptor est-il un container ?
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

Discussions similaires

  1. Choix du bon conteneur : Un vrai casse-tête !
    Par Alexoy82 dans le forum Langage
    Réponses: 29
    Dernier message: 28/11/2014, 22h50
  2. [STL] choix de conteneur
    Par ZaaN dans le forum SL & STL
    Réponses: 4
    Dernier message: 11/05/2007, 00h36
  3. [debutant] probleme de choix de conteneur
    Par Faiche dans le forum Langage
    Réponses: 3
    Dernier message: 23/12/2006, 18h13
  4. Choix du bon conteneur
    Par new.proger dans le forum C++
    Réponses: 5
    Dernier message: 09/08/2006, 00h03
  5. Réponses: 23
    Dernier message: 04/07/2006, 09h40

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