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 :

Initialisation membre statique


Sujet :

C++

  1. #1
    Membre éclairé

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 162
    Par défaut Initialisation membre statique
    Je suis entrain de créer une class FileSystem qui doit retourner un séparateur '\' si on est sous Windwos et '/' sinon.
    Mais la compilation coince à l'initialisation du membre statique.
    Voici le code :

    FilerSystem.h
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    class FileSystem
    {	
    public:
    	static const char getFileSeparator();
     
    private:
    	FileSystem();
     
    	static char separator_;
    };
    FileSystem.cpp
    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
    FileSystem::separator_ = '/';  // ERREUR ici
     
    FileSystem::FileSystem()
    {
    #ifdef WIN32
    	separator_ = '\\';
    #else
    	separator_ = '/';
    #endif
    }
     
    const char FileSystem::getFileSeparator()
    {
    	return separator_;
    }
    A la ligne d'initialisation du membre statique, le compilo me dit :
    error: expected constructor, destructor, or type conversion before '=' token

  2. #2
    Membre éclairé
    Inscrit en
    Mai 2005
    Messages
    73
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 73
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    const char FileSystem::separator_ = '/';
    devrait mieux marcher

  3. #3
    r0d
    r0d est déconnecté
    Membre expérimenté

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    4 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 4 288
    Billets dans le blog
    2
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    const char FileSystem::separator_ = '/';  // ERREUR ici
    Ca fonctionnera mieux ainsi

    edit: argh! grilled

  4. #4
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 258
    Par défaut
    Le ifdef bloc ifdef devrait se trouver autour de l'initialisation du membre, pas dans le constructeur, et separator devrait être const, puisqu'il ne changera pas tout au long de l'exécution.

    stillman et r0d : le membre n'est pas const dans le post original, donc pas de const dans l'initialisation

  5. #5
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 393
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    vandamme : À ma connaissance, le C++ natif ne supporte pas les constructeurs statiques (du moins, dans sa version actuelle).

    En .Net par exemple, c'est supporté.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  6. #6
    Membre éclairé
    Inscrit en
    Mai 2005
    Messages
    73
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 73
    Par défaut
    stillman et r0d : le membre n'est pas const dans le post original, donc pas de const dans l'initialisation
    C'est complètement exact ! Lecture trop rapide, désolé...

  7. #7
    Membre éclairé

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 162
    Par défaut
    Merci pour vos réponses.
    En effet le constructeur statique n'est pas supporté contrairement à .NET et je suis donc obligé de mettre le ifdef dans la déclaration de ma variable statique
    Sinon, j'avais oublié (honte à moi) le char devant l'initialisation de ma variable statique.
    Ca donne :
    FileSystem.h :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    class FileSystem
    {	
    public:
    	static const char getFileSeparator();
     
    private:	
    	static const char separator_;
    };
    FileSystem.cpp :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    #ifdef WIN32
    	const char FileSystem::separator_ = '\\';
    #else
    	const char FileSystem::separator_ = '/';
    #endif
     
    const char FileSystem::getFileSeparator()
    {
    	return separator_;
    }

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 22/08/2007, 20h50
  2. Réponses: 0
    Dernier message: 25/07/2007, 14h47
  3. Réponses: 5
    Dernier message: 21/07/2007, 12h30
  4. Réponses: 2
    Dernier message: 20/07/2007, 10h44
  5. Réponses: 6
    Dernier message: 22/09/2006, 13h31

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