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 :

CRTP Vs Héritage


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2006
    Messages
    366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Mai 2006
    Messages : 366
    Par défaut CRTP Vs Héritage
    Bonjour,

    Une petite question de conception. J'ai une classe DocumentManager qui peut être paramétrée par une classe de Stockage :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    template <class DocumentHandler, template<class> StoragePolicy>
    class DocumentManager : public StoragePolicy<DocumentHandler> {
    //...
    };
    Quelle que soit la classe de stockage, elle aura besoin d'accéder à une donnée membre (current_document) et deux méthodes.

    Ma question est vaut-il mieux créer une classe supplémentaire dans laquelle je vais mettre ces trois membres (2 fonctions + donnée) et en faire hériter chacune de mes classes de stockage, ou bien les inclure dans la classe DocumentManager et utiliser le CRTP :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    template <class Derived>
    class DefaultStorage {
    //...
    };
     
    template <class DocumentHandler, template <class> StoragePolicy>
    class DocumentManager : public StoragePolicy<DocumentManager>
    {
    //...
    };
    Merci d'avance.

  2. #2
    Alp
    Alp est déconnecté
    Expert confirmé

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Par défaut
    Pour ma part je pencherais pour le CRTP.

    Cette conception factorise le code sans le rendre moins souple. (ou alors je n'ai pas bien compris l'énoncé de ta question)

  3. #3
    Membre chevronné
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2006
    Messages
    366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Mai 2006
    Messages : 366
    Par défaut
    Disons que dans tous les cas le code ne se trouvera qu'à un seul endroit, la classe de DocumentManager dans le cas du CRTP, la classe de base dont héritent toutes mes classes de stockage dans l'autre cas. Après c'est plus une question de lisibilité de code et de contraintes imposées par rapport au design des classes de stockage :

    - dans le cas où je n'utilise pas le CRTP, j'impose aux designers des classes de stockage de dériver de la classe de base.
    - l'enrichissement de ma classe DocumentManager passe par deux niveaux si je n'utilise pas le CRTP : les classes de stockage (inévitable quelle que soit la solution que je choisis) et la classe de base.

    Disons que dans les deux cas il existe des contraintes sur le code des classes de stockage, c'est juste une manière différente de les exprimer. Dans le cas où je n'utilise pas le CRTP ces contraintes font partie d'une classe de base, mais qui enrichira la class DocumentManager, donc les utilisateurs de cette classe devront connaître toute la hiérarchie, dans le cas où j'utilise le CRTP les contratintes sont exprimées dans la classe dérivé (autrement dit DocumentManager) et les utilisateurs ne doivent se soucier que de l'enrichissement dû à la classe de stockage utilisée.

    Reformulé de manière plus général, la question serait : faut-il utiliser le CRTP uniquement lorsque l'on a pas le choix, ou bien peut-on l'utiliser lorsque cela est plus pratique ?

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

    Informations professionnelles :
    Activité : aucun

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

    Reformulée ainsi, le principe général est d'utiliser ce qui sera le plus facile à utiliser pour les évolution futures et le plus simple à maintenir.

    Si le but est, comme il le semble, de créer une bibliothèque que d'autres utiliseront, il me semble de bon ton de veiller à ce que ta bibliothèque reste le plus simple et le plus pratique possible à utiliser, quitte à perdre un peu de simplicité de ton côté

    Quoi qu'il en soit, la question aurait sans doute dû être débattue dés l'analyse de base, et la solution décidée (envisagée) à ce moment là doit être respectée.

    S'il s'agit c'est une question "subsidiaire" (AKA d'une question qui n'était pas apparue directement lors de l'analyse de base), il s'agirait normalement de reprendre l'analyse en vue d'y répondre afin de s'assurer que la réponse reste cohérente avec le reste (et les cas d'utilisation, entre autres)
    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

  5. #5
    Membre chevronné
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2006
    Messages
    366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Mai 2006
    Messages : 366
    Par défaut
    Citation Envoyé par koala01 Voir le message
    Salut,

    Reformulée ainsi, le principe général est d'utiliser ce qui sera le plus facile à utiliser pour les évolution futures et le plus simple à maintenir.

    Si le but est, comme il le semble, de créer une bibliothèque que d'autres utiliseront, il me semble de bon ton de veiller à ce que ta bibliothèque reste le plus simple et le plus pratique possible à utiliser, quitte à perdre un peu de simplicité de ton côté
    Dans ce cas le CRTP semble plus approprié, tant pour la doc (deux niveaux de classe au lieu de trois pour les méthodes offertes par DocumentManager) que pour la possibilité d'écrire d'autres classes de stockage.

    Merci beaucoup pour vos réponses

  6. #6
    Membre éclairé Avatar de cynique
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 60
    Par défaut
    Salut,

    C'est bizarre, en le cas de CRTP, d'avoir une StoragePolicy paramétrée par DocumentManager. La StoragePolicy dit comme on stocke son paramétre, et le paramétre est une DocumentManager. Je crois que la DocumentManager gestionne les Documents (ou, peut-etre, les DocumentHandlers), et elle a besoin d'une méthode de les stocker. La StoragePolicy est cette méthode.


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

Discussions similaires

  1. [Postgresql]Héritage
    Par lheureuxaurelie dans le forum PostgreSQL
    Réponses: 13
    Dernier message: 02/10/2008, 09h18
  2. [Héritage] Vos commentaires....
    Par Fyna dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 03/05/2005, 22h10
  3. [XML Schemas]héritage multiple
    Par nicolas_jf dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 10/06/2003, 12h55
  4. [Postgres] Héritage + Clés
    Par k-reen dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 21/05/2003, 16h37
  5. Héritage entre Forms
    Par BarBal dans le forum Composants VCL
    Réponses: 7
    Dernier message: 29/08/2002, 17h44

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