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 :

définition de conteneur


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Inactif
    Inscrit en
    Avril 2009
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 55
    Par défaut définition de conteneur
    bonjours,


    je veux definir un nouveau conteneur qui supporte un type générique c.a.d

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    conteneur<véhicule> cont;
    dans la mesure ou je peux faire
    là ou param peut etre une classe dérivée de véhicule.


    merci!!!!!!!!!!!!!!

  2. #2
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Bonjour,
    Tu pourras trouver des informations dans la FAQ :
    1/Sur les conteneurs de la STL ;
    2/Sur les template ;
    3/Et sur l'héritage.

    Je t'invite aussi à consulter les tutoriels pour te familiariser avec le C++.

  3. #3
    Inactif
    Inscrit en
    Avril 2009
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 55
    Par défaut
    bon
    je reformalise mon but:
    je voudrai definir un conteneur qui peut contenir un type de classe et les types dérivés de cette classe et ensuite acceder aux methodes de chaque classe.
    le problème que j'ai rencontré avec les conteneurs est:
    si je défini
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    vector <nom_classe_de_base*> myvector;
    et ainsi si j"essaye de faire un push_back d'un element de type classe dérivée il va pas ce passer!!!
    tu voire avec moi maintenat le pb.

    merci d'avance

  4. #4
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Les conteneurs classiques type std::vector fonctionnent très bien en général et par rapport à ton problème aussi. As-tu consulter la documentation les concernant ?
    A titre d'information, si tu refais ton propre conteneur (à moins que ce soit dans un but d'apprentissage), tu as de grande chance de faire quelque chose de plus bancale. Il n'est pas recommandé de réinventer la roue.

  5. #5
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Par défaut
    Sujet traité cent fois.

    Plusieurs solutions :
    std::vector< std::unique_ptr<nom_classe_de_base> >
    std::vector< clone_ptr<nom_classe_de_base> >
    std::vector< std::shared_ptr<nom_classe_de_base> >
    boost::ptr_vector<nom_classe_de_base>
    std::vector< boost::varianet<nom_classe_de_base, nom_classe_derivee1, ..., nom_classe_deriveen> >

    et encore plein d'autres.

    En tous cas, std::vector<nom_classe_de_base*> est en effet la pire solution qu'il y ait, bien qu'elle soit beaucoup utilisée.

  6. #6
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Salut,

    Le problème, c'est que si tu décide, à un moment donné, de faire passer un objet de type dérivé pour un objet du type de base, il n'y a rien à faire, tant que tu ne précise pas que c'est en réalité bel et bien un objet du type dérivé, tu ne pourra accéder qu'aux méthodes définies dans le type de base...

    Maintenant, ce que tu peux envisager de faire, surcharger une fonction dont la seule différence au niveau de la surcharge intervient sur le type dérivé pris en argument, de telle manière à être sur, dans chaque version de la fonction, du type réel manipulé et donc... d'être en mesure d'appeler l'ensemble des fonctions qui le composent...

    Une autre solution pourrait passer par un design pattern "chain of responsability"
    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

Discussions similaires

  1. [XSD] définition d'un élément conteneur
    Par kij dans le forum Valider
    Réponses: 2
    Dernier message: 17/01/2008, 17h11
  2. Réponses: 2
    Dernier message: 29/07/2003, 12h52
  3. [Sybase] Définition des symboles
    Par SoaB dans le forum Sybase
    Réponses: 5
    Dernier message: 19/03/2003, 23h06
  4. Définition de "Métalangage"
    Par No dans le forum Langages de programmation
    Réponses: 5
    Dernier message: 19/07/2002, 14h05

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