如下为类型CMyString的声明,请为该类型添加赋值运算符函数。
class CMyString
{
public:
CMyString(char * pData = NULL);
CMyString(const CMyString & str);
~CMyString(void);
private:
char * m_pData;
};
需要关注的点:
1.是否把返回值的类型声明为引用,并在函数结束前返回实例自身的引用,只有返回引用才可以连续赋值。
2.是否把传入参数的值声明为常量引用,如果传入的参数不是引用而是实例,那么从形参到实参会调用一次复制构造函数,把参数声明为引用可以避免无谓消耗,同时,在赋值运算符函数内不会改变传入实例的状态,因此应该为传入的引用参数加上const关键字。
3.是否释放实例自身已有的内存,如果忘记在分配新内存前释放自身已有空间,程序将出现内存泄漏。
4.是否判断传入的参数和当前的实例(*this)是不是同一个实例:如果是同一个,那么则直接返回,
以下是经典的解法:
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;
}