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

SL & STL C++ Discussion :

Surcharge d'opérateur << et std::endl;


Sujet :

SL & STL C++

  1. #1
    Membre confirmé
    Inscrit en
    Juin 2004
    Messages
    76
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 76
    Par défaut Surcharge d'opérateur << et std::endl;
    Bonjour à tous,

    Je suis actuellement en train d'écrire un logger pour mon projet et pour qu'il soit le plus simple à utiliser j'ai décidé de surcharger << pour écrire dedans. Le problème que j'ai, est que j'obtiens une erreur de compilation quand je veux revenir à la ligne par std::endl. Je ne comprends pas vraiment pourquoi, c'est pourquoi je solicite votre aide.

    J'utilise Visual C++ 2005 Express

    Voici la surcharge de mon opérateur <<, à priori, relativement standard

    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
    template <class T> CLogger& CLogger::operator <<( const T& _strLog )
    {
        // Si on est en début de ligne, on affiche l'heure. On regarde donc si le précédent
        // caractère est un retour chariot "\n"
     
        long pos = m_File.tellp();        // On récupère la position du pointeur put
        m_File.seekg( pos-1 );            // On positionne le pointeur get un caractère avant
        char prev_char = m_File.peek();    // Le caractère précédent
        m_File.seekp( pos );    // On repositionne le pointeur put à sa position d'écriture
     
        if ( prev_char == '\n' )
        {
            m_File << "[" << CurrentTime() << "]: ";
        } // if
     
        // Puis on logg le message
        m_File << _strLog;
     
        return *this;
     
    } // operator <<
    En ce qui concerne l'utilisation, voici le code pour executer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    #include "Logger.hpp"
    #include <iostream>
    #include <string>
    using namespace std;
     
     
    void main()
    {
        CLogger* logger = new CLogger();
        *logger << "prout " << "pouet \n";
        *logger << std::endl;
        *logger << "nouvelle ligne, nouveau challenge\n";
        delete logger;
    }
    Et finalement la sortie du compilo. Je précise que je n'ai aucune erreur quand j'enlève la ligne contenant endl;

    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
    37
    38
    ------ Début de la régénération globale : Projet : AM_Tools, Configuration : Debug Win32 ------
    Suppression des fichiers de sortie et des fichiers intermédiaires du projet 'AM_Tools', configuration 'Debug|Win32'
    Compilation en cours...
    Logger.cpp
    Main.cpp
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'CLogger &CLogger::operator <<(const T &)' : could not deduce template argument for 'overloaded function type' from 'overloaded function type'
            d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(15) : see declaration of 'CLogger::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'CLogger &CLogger::operator <<(const T &)' : could not deduce template argument for 'overloaded function type' from 'overloaded function type'
            d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(15) : see declaration of 'CLogger::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2896: 'CLogger &CLogger::operator <<(const T &)' : cannot use function template 'std::basic_ostream<_Elem,_Traits> &std::endl(std::basic_ostream<_Elem,_Traits> &)' as a function argument
            c:\program files\microsoft visual studio 8\vc\include\ostream(937) : see declaration of 'std::endl'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<_Elem,_Traits> &std::operator <<(std::basic_ostream<_Elem,_Traits> &,const std::basic_string<_Elem,_Traits,_Alloc> &)' : could not deduce template argument for 'std::basic_ostream<_Elem,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\string(538) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<char,_Traits> &std::operator <<(std::basic_ostream<char,_Traits> &,unsigned char)' : could not deduce template argument for 'std::basic_ostream<char,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(927) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<char,_Traits> &std::operator <<(std::basic_ostream<char,_Traits> &,const unsigned char *)' : could not deduce template argument for 'std::basic_ostream<char,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(920) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<char,_Traits> &std::operator <<(std::basic_ostream<char,_Traits> &,signed char)' : could not deduce template argument for 'std::basic_ostream<char,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(913) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<char,_Traits> &std::operator <<(std::basic_ostream<char,_Traits> &,const signed char *)' : could not deduce template argument for 'std::basic_ostream<char,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(906) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<_Elem,_Traits> &std::operator <<(std::basic_ostream<_Elem,_Traits> &,_Elem)' : could not deduce template argument for 'std::basic_ostream<_Elem,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(868) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<_Elem,_Traits> &std::operator <<(std::basic_ostream<_Elem,_Traits> &,const _Elem *)' : could not deduce template argument for 'std::basic_ostream<_Elem,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(822) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<char,_Traits> &std::operator <<(std::basic_ostream<char,_Traits> &,char)' : could not deduce template argument for 'std::basic_ostream<char,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(782) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<char,_Traits> &std::operator <<(std::basic_ostream<char,_Traits> &,const char *)' : could not deduce template argument for 'std::basic_ostream<char,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(735) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<_Elem,_Traits> &std::operator <<(std::basic_ostream<_Elem,_Traits> &,char)' : could not deduce template argument for 'std::basic_ostream<_Elem,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(697) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2784: 'std::basic_ostream<_Elem,_Traits> &std::operator <<(std::basic_ostream<_Elem,_Traits> &,const char *)' : could not deduce template argument for 'std::basic_ostream<_Elem,_Traits> &' from 'CLogger'
            c:\program files\microsoft visual studio 8\vc\include\ostream(650) : see declaration of 'std::operator <<'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\main.cpp(11) : error C2676: binary '<<' : 'CLogger' does not define this operator or a conversion to a type acceptable to the predefined operator
    Generating Code...
    Le journal de génération a été enregistré à l'emplacement "file://d:\Mes Documents\Visual Studio 2005\Projects\AM_Tools\AM_Tools\Debug\BuildLog.htm"
    AM_Tools - 15 erreur(s), 0 avertissement(s)
    ========== Régénération globale : 0 a réussi, 1 a échoué, 0 a été ignoré ==========
    Je vous remercie par avance de votre aide. Si il s'avère que je ne peux pas utiliser endl dans ce cas, tant pis mais ça me ferait changer mes habitudes :p

  2. #2
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    En fait std::endl est une fonction, pas un objet ou un caractère, donc il va avoir du mal
    Il te faut surcharger << de manière à ce qu'il prenne un std::endl en argument, ou peut-être mieux, dériver de basic_ostream.

  3. #3
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Ce qu'il faut faire, c'est definir ton propre streambuf.

    J'ai pas le temps de m'etendre la dessus. Recherche streambuf et "James Kanze" sur fr.comp.lang.c++ avec groups.google et tu devrais tomber sur des choses interessantes.

  4. #4
    Membre confirmé
    Inscrit en
    Juin 2004
    Messages
    76
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 76
    Par défaut
    Rebonjour

    Merci déjà pour vos réponses rapides. J'ai essayé de surcharger << avec un std::endl en argument mais ça me met une erreur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    CLogger& CLogger::operator << ( std::endl )
    {
        m_File << "\n";
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Compilation en cours...
    Logger.cpp
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(16) : error C2061: syntax error : identifier 'endl'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(16) : error C2805: binary 'operator <<' has too few parameters
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(51) : error C2761: 'CLogger &CLogger::operator <<(void)' : member function redeclaration not allowed
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(51) : fatal error C1903: unable to recover from previous error(s); stopping compilation
    Main.cpp
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(16) : error C2061: syntax error : identifier 'endl'
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(16) : error C2805: binary 'operator <<' has too few parameters
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(51) : error C2761: 'CLogger &CLogger::operator <<(void)' : member function redeclaration not allowed
    d:\mes documents\visual studio 2005\projects\am_tools\am_tools\logger.hpp(51) : fatal error C1903: unable to recover from previous error(s); stopping compilation
    Generating Code...

    En ce qui concerne les autres solutions proposées, c'est pas un peu lourd pour simplement pouvoir utiliser endl ?

    Merci encore pour votre aide

  5. #5
    Expert confirmé
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 292
    Par défaut
    Je ne veux pas te décourager ou quoi que ce soit, mais tu n'y arriveras pas comme ça.

    La solution idiomatique, c'est de définir son propre streambuf (cf la faq de fclc++) comme Jean-Marc l'a déjà signalé.
    La solution bourrine, c'est de se souvenir que endl (ainsi les autres manipulateurs de flux) est une fonction.
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

  6. #6
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par Tourix
    En ce qui concerne les autres solutions proposées, c'est pas un peu lourd pour simplement pouvoir utiliser endl ?
    C'est beaucoup plus diffcile d'arriver a faire fonctionner correctement ton approche.

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 33
    Par défaut
    Je rencontre exactement le mm pb que Tourix pour la mm raison d'ailleurs (un logger ) et j'ai beau cherché via streambuf,je ne vois pas comment faire.

    Qqu'un aurait-il l'amabilité de m'aider svp.

  8. #8
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par teto
    Je rencontre exactement le mm pb que Tourix pour la mm raison d'ailleurs (un logger ) et j'ai beau cherché via streambuf,je ne vois pas comment faire.

    Qqu'un aurait-il l'amabilité de m'aider svp.

    Tu regardes le code dans la FAQ de fclc++ (dans la signature de Luc) et puis tu poses
    une question precise avec le code correspondant.

Discussions similaires

  1. surcharger std::endl ?
    Par ambroise_petitgenet dans le forum SL & STL
    Réponses: 2
    Dernier message: 28/03/2009, 14h47
  2. Problème de surcharge d'opérateur std::cout
    Par Nyko17 dans le forum C++
    Réponses: 14
    Dernier message: 28/04/2008, 13h01
  3. [C#] Tri d'objet et surcharge d'opérateur
    Par Royd938 dans le forum Windows Forms
    Réponses: 6
    Dernier message: 17/12/2007, 00h26
  4. Cumul de surcharges d'opérateurs
    Par Nats dans le forum C++
    Réponses: 2
    Dernier message: 11/10/2004, 13h37
  5. [VB .NET] Surcharge d'opérateur
    Par Franckintosh dans le forum VB.NET
    Réponses: 2
    Dernier message: 07/09/2004, 19h05

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