[英]OVERLOADING OPERATORS = error
我正在尝试使用重载概念将3个对象c1
, c2
, c3
等同。 但这给我一个错误
error: no match for 'operator=' in 'c3 = c2. circle::operator=(((circle&)(& c1)))'
它背后的原因是什么,我该如何纠正它?
#include<iostream>
using namespace std;
class circle
{
private:
int radius;
float x,y;
public:
circle()
{}
circle(int rr,float xx,float yy)
{
radius=rr;
x=xx;
y=yy;
}
circle& operator=(const circle& c)
{
cout<<endl<<"assignment operator invoked";
radius=c.radius;
x=c.x;
y=c.y;
return *this;
}
void showdata()
{
cout<<endl<<"\n radius="<<radius;
cout<<endl<<"x coordinate="<<x;
cout<<endl<<"y coordinate="<<y<<endl;
}
};
int main()
{
circle c1 (10,2.5,2.5);
circle c2,c3;
c3=c2=c1;
c1.showdata();
c2.showdata();
c3.showdata();
return 0;
}
因此,此重载运算符将被调用两次。首先是c2 = c1,然后是c3 = c2,但是编译器如何将其与重载运算符定义进行比较?
为了链接operator=
调用,必须确保它返回引用
circle& operator=(const circle& c)
{
cout<<endl<<"assignment operator invoked";
radius=c.radius;
x=c.x;
y=c.y;
return *this;
}
c1=c2=c3
解析为c1 = (c2 = c3)
。 如果operator =
不返回引用,则c2 = c3
是右值,并且不能绑定到c1.operator =
的引用参数c1.operator =
(如果该参数是对const的引用,则可以绑定到rvalue,但是并不意味着您不应该返回参考)。
还要注意,通过const引用获取参数是有意义的,因为您不想更改您分配的参数。
还要记住三个规则 ,也就是说,如果您确实需要执行以下任一操作:
重载operator =
明确提供副本构造函数
明确提供一个析构函数
那么您可能也想做另外两个。 在您的特定情况下,您似乎根本不需要重载operator =
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.