深拷贝的现代写法


深拷贝的现代写法相比传统写法更加简单。也就是建立一个中间对象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 ;

          }

本文永久更新链接地址

相关内容