拷贝操作符AdvString operator= (AdvString &str)
#define _CRT_SECURE_NO_WARNINGS
#include <string>
using namespace std;
class AdvString
{
public:
AdvString()
{
len = 128;
m_p = new char[len];
strcpy(m_p, "");
}
AdvString(const char *p)
{
len = strlen(p) + 1;
m_p = new char[len];
strcpy(m_p, p);
}
AdvString(const AdvString &str)
{
this->len = str.len;
m_p = new char[len];
strcpy(m_p, str.m_p);
}
~AdvString()
{
delete[]m_p;
}
AdvString operator= (AdvString &str)
{
if (&str == this)
{
return *this;
}
delete[]m_p;
int len = str.len;
this->m_p = new char[len];
strcpy(m_p, str.m_p);
return *this;
}
private:
char *m_p;
int len;
};
int main()
{
AdvString advString;
AdvString advString01 = advString;
AdvString advString02;
advString02 = advString;
}
AdvString &operator= (const AdvString &str)
{
if (&str == this)
{
return *this;
}
delete[]m_p;
int len = str.len;
this->m_p = new char[len];
strcpy(m_p, str.m_p);
return *this;
}
省去一次拷贝构造函数和一次析构函数
另外还有一个好处就是:你可以把赋值操作符写成连锁的
比如string1 = string2 = string3
为了实现连锁赋值,赋值操作符必须返回一个reference指向操作符的左侧实参
这个协议不仅适用于以上的标准赋值形式,也适用于所有赋值相关运算,例如operator+=, operator-=等。
这只是个协议,并无强制性,但是这份协议被所有内置类型和标准程序库提供的类型如string,vector等共同遵守。
const int &getLen()
{
return len;
}
advString01.getLen() = 2;
IntelliSense: expression must be a modifiable lvalue