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 :

[conception] soucis sur un singleton


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    r0d
    r0d est déconnecté
    Membre expérimenté

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    4 293
    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 293
    Billets dans le blog
    2
    Par défaut [conception] soucis sur un singleton
    Bonjour tout le monde,

    je viens d'implémenter un petit logger super simple (et trés spécifique à mon appli, c'est pourquoi je ne peux pas utiliser des logger existants). Etant donné que je ne dois en avoir qu'un dans toute mon appli, j'ai estimé qu'il était légitime d'en faire un singleton.

    Voici, en gros, à quoi ressemble mon logger:
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    /// Logger.h
    // includes et autres
     
    class Logger : public std::ofstream
    {
    public:
    	static void Init(std::string filename)
    	{
    		if ( m_pInstance == NULL )
    		{
    			m_pInstance = new Logger(filename);
    			// ici, du code relatif à l'initialisation du logger			
    		}
    	}
     
    	static Logger& GetInstance()
    	{
    		if ( m_pInstance == NULL )
    		{
    			m_pInstance = new Logger();
    		}
    		return *m_pInstance;
    	}
     
    	// destructor (bon, en réalité, le destructeur est privé)
    	~CLogger(){close();}
     
    private:
    	// constructor
    	Logger(std::string filename = "c:/temp/log.txt") 
    		: std::ofstream( filename.c_str(), std::ios::app  ) 
    	{}
     
    	// unique Logger instance
    	static CLogger* m_pInstance;
    };
    Je déclare et j'initialise le singleton dans Logger.cpp
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ///Logger.cpp
    #include "CLogger.h"
     
    CLogger* CLogger::m_pInstance = NULL;
    Bon, mon code fonctionne, mais j'ai 2 problèmes:
    1/ J'aimerais forcer l'utilisateur de cette classe à initialiser le logger. En gros, j'aurais aimé faire en sorte que si Logger::Init(monfichier); n'est pas appelé, ça génère une erreur à la compilation.
    Mais je ne vois vraiment pas comment faire. Est-ce seulement possible?

    2/ J'utilise un outil d'analyse de code qui me hurle dessus à la ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CLogger* CLogger::m_pInstance = NULL;
    En gros, il me dit: "This non-local object will be initialised at runtime."
    Et il me dit d'aller voir l'item #47 du livre "Effective C++, 2nd edition" de Scott Meyers.
    Ce que j'ai fais. Et je ne suis pas plus avancé, car j'ai l'impression que mon implémentation est fidèle aux conseils du livre.
    Voyez-vous où est mon erreur?


    note: afin de simplifier l'utilisation de ce logger, j'ai défini les macros suivantes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    #define LOG(X) CLogger::GetInstance() << X << std::endl
    #define INIT_LOG(X) CLogger::Init(X)
    Ce qui me permet de l'utiliser ainsi:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INIT_LOG("c:/temp/log.txt");
    LOG( "test " << 1234 << UnObjet << std::endl );

  2. #2
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    essai

    avec des pragma, #define ... tu doit pouvoir faire ce que tu veut (pour vc2005)

    J'ai peut etre pas compris ton problème

  3. #3
    Expert confirmé

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2007
    Messages
    4 253
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2007
    Messages : 4 253
    Billets dans le blog
    3
    Par défaut
    Je suis peut etre trop parano....
    Mais je vois un "new" et pas de "delete" associé.... en tant qu'utilisateur ca me ferait peur


    Pourquoi ne pas faire simplement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
        static Logger& Logger::GetInstance()
        {
            static Logger myInstance;
            return myInstance; 
        }
    ??

    Sinon, vérifier à la compilation qu'une fonction est bien appelée... je vois pas comment tu peux faire !

  4. #4
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    pour moi se serait mieux de faire dans logger.cpp

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    #include "CLogger.h"
     
    CLogger* CLogger::m_pInstance = new CLogger();
    et dans la fonction Init :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    static void Init(std::string filename)
    	{
    	if ( m_pInstance != NULL )
    		 {
    		 delete 	m_pInstance;
                     m_pInstance = NULL;
    		  }
           m_pInstance = new Logger(filename);
    			// ici, du code relatif à l'initialisation du logger	
    	}

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

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    4 293
    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 293
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par nicroman
    Je suis peut etre trop parano....
    Mais je vois un "new" et pas de "delete" associé.... en tant qu'utilisateur ca me ferait peur
    Je n'ai pas mis tout le code ici. Je fais le delete dans le destructeur

  6. #6
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Par défaut
    Je fais le delete dans le destructeur
    Pas le destructeur de CLogger j'espère

    Sinon, tu as quoi exactement dans la partie "initialisations" ?

  7. #7
    Membre Expert

    Profil pro
    Inscrit en
    Juin 2006
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Localisation : Royaume-Uni

    Informations forums :
    Inscription : Juin 2006
    Messages : 1 294
    Par défaut
    Salut,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    static void Init(std::string filename)
    C'est sans doute const std::string& non ?

    MAT.

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

Discussions similaires

  1. [MySQL] souci sur conception requete
    Par fey dans le forum PHP & Base de données
    Réponses: 13
    Dernier message: 03/10/2008, 10h09
  2. [Conception] Question sur un code permettant de connaître le nombre de connectés
    Par inferno66667 dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 19/12/2005, 19h49
  3. [C#] Petit soucis sur un TreeView ...
    Par hobotalker dans le forum Windows Forms
    Réponses: 8
    Dernier message: 29/11/2005, 15h33
  4. Petit souci sur la libération d'une connexion tcp
    Par alexandre75 dans le forum Développement
    Réponses: 1
    Dernier message: 08/11/2005, 19h43
  5. souci sur ajout de données de zone de liste
    Par Tierisa dans le forum IHM
    Réponses: 6
    Dernier message: 27/09/2005, 08h30

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