题目:如下为类型CMyString 的声明,请为该类型添加赋值运算符函数。
(代码见书第二版,25页)
关键点有:
1.把返回值的类型声明为该类型的引用,并在函数结束前返回实例自身的引用(*this)。只有返回一个引用,才可以允许连续赋值。
2.把传入的参数的类型声明为常量引用。如果传入的参数不是引用而是实例,那么从形参到实参会调用一次复制构造函数。把参数声明为引用可以避免这样的无谓消耗,能提高代码的效率。同时,我们在赋值运算符函数内不会改变传入的实例的状态,因此应该为传入的引用参数加上const关键字。
3.释放实例自身已有的内存,避免内存泄漏。
4.判断传入的参数和当前的实例(*this)是不是同一个实例。
经典的解法:
CMyString& CMyString::operator=(const CMyString &str)
{
if(this==&str)
return *this;
delete []m_pData;
m_pData=nullptr;
m_pData=new char[strlen(str.m_pData)+1];
strcpy(m_pData,str.m_pData);
return *this;
}
考虑异常安全性的解法:
CMyString& CMyString::operator=(const CMyString &str)
{
if(this!=&str)
{
CMyString strTemp(str);
char* pTemp=strTemp.m_pData;
strTemp.m_pData=m_pData;
m_pData=pTemp;
}
return *this;
}
测试用例:
a.把一个CMyString 的实例赋值给另一个实例。
b.把一个CMyString 的实例赋值给它自己。
c.连续赋值。