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 :

Nommage d'interface et Microsoft


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2010
    Messages
    188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haut Rhin (Alsace)

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

    Informations forums :
    Inscription : Novembre 2010
    Messages : 188
    Par défaut Nommage d'interface et Microsoft
    Bonjour,
    Une petite question de convention de nommage que j'applique depuis longtemps mais qui me laisse pantois devant certains nommages de Microsoft lui-même...
    J'ai des interfaces que je nomme habituellement IMyObect pour l'objet MyObject => Je l'applique depuis longtemps
    Par contre en regardant un peu ce qu'il y a dans système.reflexion, certaines interfaces sont nommées _MyObject (par exemple _MemberInfo ou _PropertyInfo) Je trouve cela intéressant comme ça les interfaces ne sont pas au milieu des objets commençant par I... Qu'en pensez-vous ?

    Merci

  2. #2
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Billets dans le blog
    3
    Par défaut
    Je ne sais pas si c'est volontaire de la part de Microsoft. Ca peut etre du a une refactorisation de ton logiciel de decompilation…

    En tout cas dans la doc officielle, Microsoft recommande l'usage de la letter "I" : Noms de classes, de structures et d'interfaces. Apres ca ne reste qu'une suggestion de convention, chacun est libre d'utiliser ce qu'il souhaite. Il faut juste savoir que pour integrer des developpeurs sur un projet, c'est plus simple en suivant les conventions les plus connues. Si tu utilises ta propre convention, il faut documenter et prevoir du temps pour que tes gars trouvent leurs marques.

    Sinon pour isoler les interfaces du reste des objets, tu peux les conserver au sein d'un projet distinct. Par exemple :
    • TonProjet.TonNamespace (qui contient les implementations)
    • TonProjet.TonNamespace.Interfaces (qui ne contient que les interfaces)


    Si tu utilises l'injection de dependences, ce genre de structure est plutot habituel, mais pas obligatoire.
    Less Is More
    Pensez à utiliser les boutons , et les balises code
    Desole pour l'absence d'accents, clavier US oblige
    Celui qui pense qu'un professionnel coute cher n'a aucune idee de ce que peut lui couter un incompetent.

  3. #3
    Membre expérimenté
    Homme Profil pro
    Analyste Programmeur
    Inscrit en
    Septembre 2008
    Messages
    176
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Analyste Programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 176
    Par défaut
    Bonjour,

    En regardant sur les sources de référence fournis par Microsoft, ils utilisent les deux préfixes I et _ pour les interfaces, par exemple pour MemberInfo (https://referencesource.microsoft.co...37137ea25e482a)

    Je n'ai aucune idée du pourquoi, peut-être un reste avant qu'il utilise la convention du I.

    Personnellement, je reste sur le I, comme le dit DotNetMatt, ça reste la plus connue et la plus simple à intégrer.

    Bonne continuation.

  4. #4
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2010
    Messages
    188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haut Rhin (Alsace)

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

    Informations forums :
    Inscription : Novembre 2010
    Messages : 188
    Par défaut
    OK, je vous remercie

  5. #5
    Expert confirmé

    Avatar de François DORIN
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2016
    Messages
    2 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Charente Maritime (Poitou Charente)

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

    Informations forums :
    Inscription : Juillet 2016
    Messages : 2 761
    Billets dans le blog
    21
    Par défaut
    Très pertinente cette remarque.

    En regardant un peu le code, j'ai peut être des éléments de réponse à donner. Je pense que c'est une convention de nommage volontaire et réfléchie.

    On peut constater, pour l'interface _MemberInfo, que les membres définis dépendent de la directive préprocesseur FEATURE_CORECLR.
    Ensuite, il est marqué que ces interfaces ne sont pas CLS Compliant (en gros, cela signifie que le code n'est pas langage agnostique et donc qu'il dépend du C#. Il ne sera pas forcément possible de l'utiliser depuis un autre langage comme VB.NET).
    De plus, l'interface est implémentée de manière explicite. Autrement dit, à moins d'avoir une variable de type _MemberInfo, il ne sera pas possible d'appeler les méthodes défini par cette interface.
    Enfin, l'interface est visiblement présente pour une interopérabilité COM.

    Comme cette interface n'a pas vocation a être utilisée dans du code managé, mais qu'elle est nécessaire publique puisque c'est un composant COM, Microsoft "masque" l'interface en usant une convention différente de celle recommandée.

  6. #6
    Membre Expert
    Homme Profil pro
    edi
    Inscrit en
    Juin 2007
    Messages
    941
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : edi

    Informations forums :
    Inscription : Juin 2007
    Messages : 941
    Par défaut
    Personnellement je suis tombé sur ce formalisme en travaillant sur des plugins MS Office. Dans interop (Microsoft.Office.Interop.<Word/Excel/Outlook/...> pour accéder aux objets COM on trouve des interfaces _Application (exemple) qui doivent utilisées explicitement dans des cas précis ; notamment pour pallier des ambigüités de nommage entre des événements, méthodes ou propriétés.

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

Discussions similaires

  1. Réponses: 32
    Dernier message: 11/09/2009, 10h10
  2. Réponses: 5
    Dernier message: 31/12/2008, 14h56
  3. [preferences] nommage class, interface, enum
    Par visiwi dans le forum Eclipse Java
    Réponses: 0
    Dernier message: 29/08/2008, 15h19
  4. probléme entrée interface microsoft sql server 2005
    Par ess2007 dans le forum Administration
    Réponses: 2
    Dernier message: 01/07/2008, 17h03
  5. [Language]Nommage d'interface
    Par Tiaps dans le forum Langage
    Réponses: 4
    Dernier message: 29/11/2005, 01h28

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