深拷贝的现代写法相比传统写法更加简单。也就是建立一个中间对象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是实参的一份拷贝) { swap(_str, s._str); return *this ; }