深拷贝的现代写法相比传统写法更加简单。也就是建立一个中间对象tmp,它的_str指针指向的内容是s._str的一份拷贝,交换tmp._str和_str后,_str就指向了s._str那份拷贝,出了作用域tmp会自动调用它的析构函数,也就把原先_str指向的内存释放了,同样达到了我们要的效果。
如下图:
#include<iostream>
using namespace std;
class String
{
public:
String(char * str="") //不能strlen(NULL)
:_str(new char [strlen(str ) + 1])
{
strcpy(_str, str);
}
String(const String &s)
:_str(NULL )
{
String tmp(s ._str);
swap(_str,tmp._str);
}
String& operator=(const String& s)
{
if (this != &s)
{
String tmp(s._str);
swap(_str, tmp._str);
}
return *this;
}
~String()
{
delete[] _str;
}
private:
char* _str;
};
当然,这里的赋值运算符重载还可以进行再优化:
String& operator=(String s) //优化 (s不能加引用,否则会改变实参的值)(这里的s是实参的一份拷贝)