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 :

gcc vs Visual


Sujet :

C++

  1. #1
    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
    Points : 13 017
    Points
    13 017
    Par défaut gcc vs Visual
    Soit le code suivant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    class A
    {
    public:
       A(){}
       void MaMethode(){std::cout<<"coucou\n";}
    };
     
    int main()
    {
       A a;
       typedef void (A::*tdMethodeSurA)();
       tdMethodeSurA MethodeSurA;
       MethodeSurA  = &(A::MaMethode);
       (a.*MethodeSurA)();
    }
    Ca compile avec VC++Express mais pas avec gcc. Pourquoi?
    La ligne de commande gcc est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    g++ -c -o Debug\obj\main.o -g -O0 -mthreads  -W -Wall -DNOPCH   -Wno-ctor-dtor-privacy   -MTDebug\obj\main.o -MFDebug\obj\main.o.d -MD Sources/main.cpp
    L'erreur est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Sources/main.cpp:82: error: invalid use of non-static member function `void A::MaMethode()'
    Sources/main.cpp:82: error: parenthesis around 'A::MaMethode' cannot be used to form a pointer-to-member-function

  2. #2
    Rédacteur

    Avatar de Davidbrcz
    Homme Profil pro
    Ing Supaéro - Doctorant ONERA
    Inscrit en
    Juin 2006
    Messages
    2 307
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ing Supaéro - Doctorant ONERA

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 307
    Points : 4 732
    Points
    4 732
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MethodeSurA  = &(A::MaMethode);
    Tel que le code est fait, tu assigne à MethodeSurA, l'adresse de ce que retourne la fonction statique MaMethode appartenant à la classe A, qui par ailleur est mal appelée (manque les parenthèses).

    Pour que ca compile, enlève les parenthèses (comme te le fait remarque gcc).

    PS 1: en lisant le titre, je m'attendais à un gros troll bien poilu.
    PS 2: Je pense que c'est g++ qui à raison, VS étant assez connu pour sa complaisance façe à la norme, même si dans tous les cas, faut vérifier.
    "Never use brute force in fighting an exponential." (Andrei Alexandrescu)

    Mes articles dont Conseils divers sur le C++
    Une très bonne doc sur le C++ (en) Why linux is better (fr)

  3. #3
    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 : 49
    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
    Points : 16 213
    Points
    16 213
    Par défaut
    On dirait bien que Visual C++ est trop laxiste :

    Citation Envoyé par Le standard (dernier draft) 5.3.1/3
    A pointer to member is only formed when an explicit & is used and its operand is a qualified-id not enclosed in parentheses.
    [ Note: that is, the expression &(qualified-id), where the qualified-id is enclosed in parentheses, does not form an expression of type “pointer to member.” Neither does qualified-id, because there is no implicit conversion from a qualified-id for a non-static member function to the type “pointer to member function” as there is from an lvalue of function type to the type “pointer to function” (4.3). Nor is &unqualified-id a pointer to member, even within the
    scope of the unqualified-id’s class. —end note ]
    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.

  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
    Points : 13 017
    Points
    13 017
    Par défaut
    Merci pour les réponses.

  5. #5
    Membre éclairé Avatar de HanLee
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    738
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2004
    Messages : 738
    Points : 871
    Points
    871
    Par défaut
    Citation Envoyé par JolyLoic Voir le message
    On dirait bien que Visual C++ est trop laxiste :
    Elle est bizarre la règle quand même, pas très cohérente avec le langage mais bon.

  6. #6
    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
    Points : 13 017
    Points
    13 017
    Par défaut
    Du coup, je veux bien quelques éclairages. Quelle est la différence sémantique entre et . Pourquoi alors Visual serait trop laxiste et pas plutôt gcc trop restrictif. J'avoue qu'une réponse du type "c'est la norme" me laisserait plutôt sur ma faim.

  7. #7
    Rédacteur

    Avatar de Davidbrcz
    Homme Profil pro
    Ing Supaéro - Doctorant ONERA
    Inscrit en
    Juin 2006
    Messages
    2 307
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ing Supaéro - Doctorant ONERA

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 307
    Points : 4 732
    Points
    4 732
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MethodeSurA  = &(A::MaMethode);
    Tel que le code est fait, tu assigne à MethodeSurA, l'adresse de ce que retourne la fonction statique MaMethode appartenant à la classe A, qui par ailleur est mal appelée (manque les parenthèses)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MethodeSurA  = &A::MaMethode;
    Tu prend l'adresse de la fonction membre MaMethode de la classe pour l'assigner à MethodeSurA.

    Pourquoi alors Visual serait trop laxiste et pas plutôt gcc trop restrictif. J'avoue qu'une réponse du type "c'est la norme" me laisserait plutôt sur ma faim.
    Et c'est pourtant la vérité. Loic à cité le passage de la norme qui appuie que c'est bien g++ qui a raison.
    "Never use brute force in fighting an exponential." (Andrei Alexandrescu)

    Mes articles dont Conseils divers sur le C++
    Une très bonne doc sur le C++ (en) Why linux is better (fr)

  8. #8
    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
    Points : 13 017
    Points
    13 017
    Par défaut
    J'insiste mais en quoi (A::MaMethode) est évaluée différemment de A::MaMethode? Je comprend l'explication de Davidbrcz si j'écris &(A::MaMethode()). Au quel cas, oui l'expression (A::MaMethode()) vaut le retour de MaMethode. Mais, pourquoi (A::MaMethode) n'est-ce pas évaluée comme A::MaMethode?

  9. #9
    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 : 49
    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
    Points : 16 213
    Points
    16 213
    Par défaut
    Parce que c'est comme ça...

    Il y a probablement une raison plus satisfaisante (genre une ambiguïté que cette règle permet de lever, ou une difficulté à implémenter le cas général), mais je ne la connais pas, et à première vue, je ne vois pas en quoi elle consisterait.

    Autoriser &(A::f) signifierait que l'opérateur & appliqué à une expression (et non pas directement un nom de fonction membre) peut retourner un pointeur de fonction membre, ce qui est peut-être trop complexe à gérer.
    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.

  10. #10
    Expert éminent

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Points : 6 911
    Points
    6 911
    Par défaut
    & s'applique a des l-values ou a des identificateurs. Pour accepter &(A::m) ou meme &(f), il faudrait que (A::m) et (f) soient des l-values. Hors le C++ n'a pas de type fonction ou fonction membre..
    Les MP ne sont pas là pour les questions techniques, les forums sont là pour ça.

  11. #11
    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
    Points : 13 017
    Points
    13 017
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    & s'applique a des l-values ou a des identificateurs. Pour accepter &(A::m) ou meme &(f), il faudrait que (A::m) et (f) soient des l-values. Hors le C++ n'a pas de type fonction ou fonction membre..
    Je chipote mais alors pourquoi accepter &A::m?
    En fait au début, j'avais tendance à penser comme JolyLoic: il devait y avoir une ambigüité ou une difficulté pour l'implémentation du compilo, mais je n'arrive pas à voir laquelle.

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

Discussions similaires

  1. Conversion gcc vers visual C++
    Par réciproxy dans le forum Windows
    Réponses: 14
    Dernier message: 23/08/2010, 13h02
  2. différences de syntaxe entre gcc et visual C?
    Par jlandrei dans le forum C
    Réponses: 13
    Dernier message: 27/10/2009, 10h27
  3. Traduction assembleur GCC vers Visual Studio 2008
    Par moldavi dans le forum x86 32-bits / 64-bits
    Réponses: 6
    Dernier message: 22/10/2009, 20h20
  4. Grosse différence de perf en GCC et Visual avec les STL
    Par vanitom dans le forum Visual C++
    Réponses: 4
    Dernier message: 28/04/2009, 09h35
  5. template, héritage virtuel: gcc vs Visual II
    Par 3DArchi dans le forum Langage
    Réponses: 5
    Dernier message: 07/08/2008, 15h53

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