题目:如下为类型为CMyString的声明,请为该类型添加赋值运算符函数
class CMyString
{
public:
CMyString(char* pData = NULL);
CMyString(const CMyString& str);
~CMyString(void);
private:
char* m_pData;
};
【考察点】
1、是否把返回值的类型声明为该类型的引用
2、是否把传入的参数声明为常量引用
3、是否释放实例自身有的内存
4、是否判断传入的参数和当前的实例(*this)是不是同一个实例
【代码】
class CMyString
{
public:
CMyString(char* pData = NULL);
CMyString(const CMyString& str);
CMyString& operator=(const CMyString& str);
~CMyString(void);
private:
char* m_pData;
};
CMyString::CMyString(char* pData)
{
//方便测试查看,实际不用给出
cout << "CMyString(char* pData)" << endl;
}
CMyString::CMyString(const CMyString& str)
{
cout << "CMyString(const CMyString& str)" << endl;
}
CMyString::~CMyString(void)
{
cout << "~CMyString(void)" << endl;
}
CMyString& CMyString::operator=(const CMyString& str)
{
cout << "CMyString::operator=(const CMyString& str)" << endl;
if (this != &str)
{
//先创建一个临时对象,再交换临时实例和原来的实例
CMyString ret(str);
char* tmp = ret.m_pData;
ret.m_pData = m_pData;
m_pData = tmp;
}
return *this;
}
int main()
{
CMyString str1("a");
CMyString str2;
CMyString str3;
//自己给自己赋值
str1 = str1;
//给别的对象赋值
str2 = str1;
//连续赋值
str3 = str2 = str1;
system("pause");
return 0;
}