我曾经定义过运算符<<作为一个函数,就像我对大多数操作符一样。
class MyClass {
int myAttribute;
public :
MyClass(int attr):
myAttribute(attr){}
int getter() {return myAttribute;}
};
MyClass operator+(MyClass mc1, MyClass mc2)
{
MyClass mc(mc1.getter()+mc2.getter());
return mc;
}
std::ostream& operator<< (std::ostream &stream, MyClass mc)
{
stream << mc.getter();
return stream;
}
这一切都运作良好,但有人告诉我,我可以将其定义为一种方法。我删除了operator +和operator&lt;&lt;的定义我对operator +
没有任何问题MyClass MyClass::operator+(MyClass mc1)
{
MyClass mc(mc1.getter()+myAttribute);
return mc;
}
但它不能与运营商&lt;&lt;
一起使用std::ostream& MyClass::operator<< (std::ostream &stream)
{
stream << myAttribute;
return stream;
}
我收到错误:
error: no match for 'operator<<' (operand types are 'std::ostream {aka std::basic_ostream<char>}' and 'MyClass')
我想念什么?
答案 0 :(得分:4)
撰写std::ostream& MyClass::operator<< (std::ostream &stream)
时会使用MyClass m; m << std::cout;
。那不是你想要的。
如果您添加std::ostream &std::ostream::operator<<(const MyClass &m)
,那么这将适用于MyClass m; std::cout << m;
,但它需要您更改标准标题,而不能更改标准标题,因此非成员版本是唯一可行的选项。
请注意,非会员版本不属于MyClass
,因此无法访问private
MyClass
成员。如果您需要,可以将friend std::ostream& operator<< (std::ostream &stream, const MyClass &mc);
添加到MyClass
以使其成为可能。
答案 1 :(得分:1)
您的operator<<
必须是非会员功能。你不能把它变成一种&#34;方法&#34;如果您想在左侧使用std::cout
,在右侧使用您自己的班级。
但如果operator<<
需要访问private
的{{1}}数据,您可以将MyClass
声明为朋友。