今天看剑指offer第一题赋值运算符的重载时,题目说要返回一个引用,这一点不太懂,在试图弄懂这个问题的过程中,带出了许多自己不太懂的知识,在这里记录一下。
首先没有搞懂的是,=运算符是一个双目运算符,为什么在重载时只有一个形参呢?最后在primerC++中找到了答案。13.2赋值操作符
首先先说一下在C++中所有的运算符,都可以看成是一个函数,而双目运算符的参数有两个,而单目运算符的参数只有一个。
例如:
双目运算符+,- ,*,/
分别编译为 operator +(arg1, arg2) operator-(arg1,arg2) operator*(arg1,arg2) operator/(arg1,arg2)
单目运算符 -(符号)
编译为operator-(arg1)
所以按照正常情况,=作为双目运算符,应该有两个参数,第一个形参对应左操作数,第二个形参对应右操作数。但是=有些特殊。
大多数的操作符可以定义为成员函数和非成员函数,当操作符被定义为成员函数时,它的第一个操作数隐式的绑定到this指针。有些操作符必须定义为自己的类成员,=赋值操作符就是其中一个。应为赋值操作符必须是类成员,所以this自动的绑定到了做操作数。因此我们看到剑指offer上的赋值操作符只有一个形参。
下面说一下剑指offer里面说的这个问题:
先说下示例代码
CMyString& CMyString::operator=(const CMyString &str)
{
if(this == &str)
return *this;
delete []m_pData;
m_pData = NULL;
m_pData = new char[strlen(str.m_pData) +1];
strcpy(m_pData,str.m_pData);
return *this;
}
书上说要返回自己的一个引用,在前面介绍过之后,其实已经很明了了,其实这个返回值和赋值语句已经没有任何关系了,哪怕这里的函数返回值为void,对于简单的赋值已经可以实现了,而这种写法是为了防止出现连续赋值的情况,如:a = b = c;
我们先来解释一下这个语句的执行过程:
1.执行b=c,也就是执行函数 operator+(c)
2.得出b=c的返回值,假设为x
3.执行a=x
从上面可以看书,如果重载的赋值运算符没有返回值,那么b = c执行之后,虽然把c的值付给了b,但是这个函数执行之后,没有返回值,那么 接下来执行a = x,由于x不存在就会出错。而如果有返回值,那么x就是一个CMyString类型的值,那么就可以接下来执行a=x了。就不会出错了。