0

我正在学习 C++,但是当我尝试从 Java 代码转换为 C++ 时,我一直遇到这个错误。我在 java 中有一些类,我必须将其翻译成 c++ 代码(使用 C++ 风格的编程)。我有一个 Article 类,从 ArticleUnitaire 继承的 ArticleUnitaire 类,以及从 ArticleUnitaire 继承的 Ramette 类。所有的 getter 和 setter 都可以正常工作,问题是当我尝试执行与 c++ 等效的 toString 时,即 operator<< 重载。让我向您展示代码和错误: Java 代码:

    public abstract class Article {
      ....
      public String toString() {
        return this.getClass().getName() + ":reference=" 
          + reference + ";descriptif=" + getDescriptif() 
          + ";marque=" + getMarque() + ";PU=" + getPU();
      }

    }

public abstract class ArticleUnitaire extends Article {
  private String marque;
  private double pu;
  private String descriptif;

  public ArticleUnitaire(String reference) {
    super(reference);
  }

  public ArticleUnitaire(String reference, String descriptif, String marque,
                         double pu) {
    super(reference);
    this.marque = marque;
    this.pu = pu;
    this.descriptif = descriptif;
  }



  // useless to redefine toString because PU and descriptif
  // were also displayed by the superclass(Article)

}

public class Stylo extends ArticleUnitaire {
 ....

  @Override
  public String toString() {
    return super.toString() + ";couleur=" + couleur;
  }
}

这是我的文章.h 文件:

    #include <string>
    using namespace std;



    class Article
    {
        public:
        string getReference();
        virtual string getDescriptif() const;
        virtual double getPU() const;
        string getMarque() const;
        void Afficher(ostream&) const;
        ostream& operator<<(ostream&) const;

        protected:
        Article(string&);
            string reference;
        private:

    };

    class ArticleUnitaire : public Article {
        public:
          ArticleUnitaire(string);
          ArticleUnitaire(string, string, string, double);
          string getMarque() const;
          void setMarque(string&);
          double getPU() const;
          void setPU(double&);
          void setDescriptif(string&);
          string getDescriptif() const;
          void Afficher(ostream&) const;

        protected:
          string marque;
          double pu;
          string descriptif;
        private:

    };

    class Stylo : public ArticleUnitaire {
        public:
          Stylo(string r, string d, string m, double p, string c);
          void Afficher(ostream& os) const;
          string getCouleur();
        protected:
        private:
          string couleur;

    };

class Lot : public Article {
    public:
      Lot(string, Article, int, int);
      double getPU() const;
      string getDescriptif() const;
      string getMarque() const;
      int getNbArticles() const;
      void setNbArticles(int&);
      int getPourcentage() const;
      void setPourcentage(int&);
      Article getArticle() const;
      void setArticle(Article&);
      virtual void Afficher(ostream& os) const;


    protected:
    private:
      int nb;
      int pourcentage;
      Article art;
};

还有articles.cc 文件:

    #include <typeinfo>
    #include <string>
    using namespace std;
    #include "articles.h"

    /*   Article   */

    Article::Article(string& ref) : reference(ref) {};

    string Article::getReference() {
      return reference;
    }

    ostream& Article::operator<<(ostream& os) const {
      Afficher(os);
      return os;
    }

    string Article::getMarque() const {
      return "Sans marque";
    }

    void Article::Afficher(ostream& os) const {
      os << " : reference = " << getReference() << " ; descriptif = " << getDescriptif() << " ; marque = " << getMarque() << " ; PU = " << getPU();
    }

    /*   Article Unitaire   */

    ArticleUnitaire::ArticleUnitaire(string r) : Article(r) {};

    ArticleUnitaire::ArticleUnitaire(string r, string d, string m, double p) : Article(r), marque(m), descriptif(d), pu(p) {};

    string ArticleUnitaire::getMarque() const {
      return marque;
    }

    void ArticleUnitaire::setMarque(string& m) {
      marque = m;
    }

    double ArticleUnitaire::getPU() const {
      return pu;
    }

    void ArticleUnitaire::setPU(double& p) {
      pu = p;
    }

    void ArticleUnitaire::setDescriptif(string& d) {
      descriptif = d;
    }

    string ArticleUnitaire::getDescriptif() const {
      return descriptif;
    }

    /*   Stylo    */

    Stylo::Stylo(string r, string d, string m, double p, string c) : ArticleUnitaire(r,d,m,p), couleur(c) {};

    string Stylo::getCouleur() {
      return couleur;
    }

    void Stylo::Afficher(ostream& os) const {
      Article::Afficher(os);
      os << " ; couleur = " << getCouleur();
    }

Lot::Lot(String r, Article a, int n, int p) : Article(r) {
  art = a;
  nb = n;
  pourcentage = p;
};
...

但是,当我尝试编译时,方法 Afficher() 始终出现相同的错误:

In member function ‘void Article::Afficher(std::ostream&) const’:
articles.cc:24:9: error: no match for ‘operator<<’ in ‘os << " : reference = "’
articles.cc:24:9: note: candidate is:
In file included from /usr/include/c++/4.7/string:54:0,
                 from articles.cc:2:
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note: template<class _CharT, class _Traits, class _Alloc> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::basic_string<_CharT, _Traits, _Alloc>&)
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note:   template argument deduction/substitution failed:
articles.cc:24:9: note:   mismatched types ‘const std::basic_string<_CharT, _Traits, _Alloc>’ and ‘const char [16]’
articles.cc:24:43: error: passing ‘const Article’ as ‘this’ argument of ‘std::string Article::getReference()’ discards qualifiers [-fpermissive]
articles.cc: In member function ‘void Stylo::Afficher(std::ostream&) const’:
articles.cc:67:9: error: no match for ‘operator<<’ in ‘os << " ; couleur = "’
articles.cc:67:9: note: candidate is:
In file included from /usr/include/c++/4.7/string:54:0,
                 from articles.cc:2:
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note: template<class _CharT, class _Traits, class _Alloc> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::basic_string<_CharT, _Traits, _Alloc>&)
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note:   template argument deduction/substitution failed:
articles.cc:67:9: note:   mismatched types ‘const std::basic_string<_CharT, _Traits, _Alloc>’ and ‘const char [14]’
articles.cc:67:39: error: passing ‘const Stylo’ as ‘this’ argument of ‘std::string Stylo::getCouleur()’ discards qualifiers [-fpermissive]
articles.cc: In member function ‘void Ramette::Afficher(std::ostream&) const’:
articles.cc:79:9: error: no match for ‘operator<<’ in ‘os << " ; grammage = "’
articles.cc:79:9: note: candidate is:
In file included from /usr/include/c++/4.7/string:54:0,
                 from articles.cc:2:
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note: template<class _CharT, class _Traits, class _Alloc> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::basic_string<_CharT, _Traits, _Alloc>&)
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note:   template argument deduction/substitution failed:
articles.cc:79:9: note:   mismatched types ‘const std::basic_string<_CharT, _Traits, _Alloc>’ and ‘const char [15]’
articles.cc:79:41: error: passing ‘const Ramette’ as ‘this’ argument of ‘int Ramette::getGrammage()’ discards qualifiers [-fpermissive]
articles.cc: At global scope:
articles.cc:84:9: error: expected constructor, destructor, or type conversion before ‘(’ token
articles.cc: In member function ‘virtual std::string Lot::getDescriptif() const’:
articles.cc:91:26: error: invalid operands of types ‘const char*’ and ‘const char [3]’ to binary ‘operator+’
articles.cc: In member function ‘void Lot::Afficher(std::ostream&) const’:
articles.cc:124:9: error: no match for ‘operator<<’ in ‘os << " ;reduction = "’
articles.cc:124:9: note: candidate is:
In file included from /usr/include/c++/4.7/string:54:0,
                 from articles.cc:2:
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note: template<class _CharT, class _Traits, class _Alloc> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::basic_string<_CharT, _Traits, _Alloc>&)
/usr/include/c++/4.7/bits/basic_string.h:2750:5: note:   template argument deduction/substitution failed:
articles.cc:124:9: note:   mismatched types ‘const std::basic_string<_CharT, _Traits, _Alloc>’ and ‘const char [15]’

如您所见,编译器不喜欢我对 operator>> 重载中使用的方法 Afficher 所做的事情。我究竟做错了什么?

4

2 回答 2

1

一些问题:

  • Stylo::getCouleur() 不是 const

  • Ramette::getGrammage() 不是 const

这是我发现的前两个

于 2012-12-20T21:12:49.487 回答
0

重载operator<<为非成员函数,而不是成员函数。这是唯一的方法,因为您希望您的对象位于运算符的右侧,而不是左侧(并且您不能更改 class std::ostream)。

编辑:但是那个非成员函数又可以调用一个虚拟成员函数......

头文件:

class Article {
public:
    virtual void Afficher(std::ostream& os) const;
    //...
};
std::ostream& operator<<(std::ostream& os, const Article& art);

class ArticleUnitaire : public Article {
public:
    virtual void Afficher(std::ostream& os) const;
    //...
};

inline std::ostream& operator<<(std::ostream& os, const Article& art) {
    art.Afficher(os);
    return os;
}

源文件:

void Article::Afficher(std::ostream& os) const {
    //...
}

void ArticleUnitaire::Afficher(std::ostream& os) const {
    Article::Afficher(os);
    //Other data...
}
于 2012-12-20T21:22:44.657 回答