c++类运算符重载遇到的函数形参问题

class A
{
public:
    A(int arg1, int arg2);
    ~A();
    A &operator = ( A &other);
    A operator + ( A &other);
private:
    int a, b;

};


A::A(int arg1, int arg2)
{
    a = arg1;
    b = arg2;
}

A::~A()
{

}
A &A::operator=( A &other)
{
    if (this == &other)
    {
        return *this;
    }

    this->a = other.a;
    this->b = other.b;
    return *this;
}

A A::operator+( A &other)
{
    return A(a+other.a, b+other.b);
//    return other;
}

上面的这个类中重载了=和+号运算符, 但是参数都是引用,而不是const的引用,这样在遇到形如

A a(1, 2);

a + A(3, 4);

的运算时就会出现错误,原因如下:

a + A(3, 4)等价于a.operator +(A(3, 4))

这里要提到的是函数的返回值不能作为左值(可以参见http://blog.csdn.net/sunshinewave/article/details/7830701

但是类中的函数声明确是

A operator + ( A &other)

说明other在函数中是可以修改的,这就产生了矛盾,所以编译器会提示无法把A类型的变量转换成A&的错误提示

总结:在类中重载运算符时要把形参表示为const A&的形式,不仅为了减少开销

 

 

posted @ 2013-07-22 17:31  没出没  阅读(979)  评论(0编辑  收藏  举报