проблема перегрузки оператора потока - PullRequest
3 голосов
/ 28 января 2011

У меня есть класс, использующий перегрузку операторов, но есть некоторые предупреждения.

// base.h

class base {
public:
    base();
    base(int n);
    virtual ~base();
    virtual void printBase(std::ofstream & out);
    virtual base & operator =(const base &);
    friend std::ofstream & operator <<(std::ofstream & out, const base &);
private:
       double * coeff;
       int n;
};

// base.cpp

std::ofstream & operator<<(std::ofstream & fout, const base & obj)
{
    for(int i =0; i<(obj.n)-1; i++)
    {
        fout << obj.coeff[i]<<"*x"<<i;
        if(i<obj.n-2)
        {
            fout<<"+";
        }
    }
    fout<<"="<<obj.coeff[(obj.n)-1];
    return fout;
}

void base::printBase(std::ofstream & fout)
{
    for(int i =0; i<n-1; i++)
    {
        fout<<coeff[i]; // warning occurs here!!
        if(i<n-2)
        {
            fout<<"+";
        }
    }
    fout<<"="<<coeff[n-1];
}

Предупреждение:

>

 warning: ISO C++ says that these are ambiguous, even though the worst conversion for
 the first is better than the worst conversion for the second:
    c:\wascana\mingw\bin\../lib/gcc/mingw32/4.5.0/include/c++/bits/ostream.tcc:105:5: note:
 candidate 1: std::basic_ostream<_CharT, _Traits>& std::basic_ostream<_CharT, _Traits>::operator<<(int) [with _CharT = char, _Traits = std::char_traits<char>]
    ..\Hyperplane.cpp:55:17: note: candidate 2: std::ofstream& operator<<(std::ofstream&, const Hyperplane&)

Из приведенного выше предупреждения, это должно быть проблемой <<.Я знаю причину, но как я могу справиться с этим предупреждением?

Спасибо!

1 Ответ

9 голосов
/ 28 января 2011

Проблема на самом деле с одним из конструкторов вашего класса:

base(int n);

Этот конструктор называется конвертирующим конструктором . Его можно использовать для преобразования int в base, поэтому это будет допустимо:

base x = 42;

Если вы не хотите разрешать это неявное преобразование, вы можете сделать конструктор explicit:

explicit base(int n);

Интересный вопрос: "где неопределенность в fout << coeff[i];?

Есть две функции-кандидата, между которыми компилятор не может выбирать (или не должен иметь возможность выбирать между ними; ваш компилятор «приятен» вам): одна - встроенная std::ostream operator<< перегрузка выглядит так:

std::ostream& operator<<(std::ostream&, double);

вторая - перегрузка вашего оператора, которая выглядит следующим образом:

std::ofstream& operator<<(std::ofstream&, const base&);

При первом кандидате первый аргумент требует преобразования из производной в основание: std::ofstream необходимо преобразовать в std::ostream для вызова функции. Второй аргумент, double, точно соответствует.

Со вторым кандидатом первый аргумент, std::ofstream, точно совпадает. Второй аргумент требует использования встроенного преобразования double в int, а затем использования вашего конструктора преобразования для преобразования из int в base.

Чтобы компилятор выбрал одну функцию-кандидата в качестве правильной для вызова, каждый из аргументов должен соответствовать как минимум соответствующему параметру кандидата, так же как и любому другому кандидату.

При наличии этих двух кандидатов первый аргумент лучше соответствует второму кандидату, но второй аргумент лучше соответствует первому кандидату, поэтому возникает неоднозначность.

Альтернативным решением было бы изменить вашу перегрузку так, чтобы первый аргумент совпадал с первым аргументом встроенного кандидата:

std::ostream& operator<<(std::ostream&, const base&);
...