深拷貝的現代寫法相比傳統寫法更加簡單。也就是建立一個中間對象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 ; }