C++String浅拷贝&深拷贝&Copy On Write

  • 简单的赋值拷贝
class String
{
public:
    String(constchar*str)
        :_str(newchar [strlen(str)+1])
    {
        strcpy(_str,str);
    }
    String(constString&str)
        :_str(str._str)
    {}
    String& operator=(constString& str)
    {
        if(this!= &str)
        {
            _str=str._str;
        }
        return *this;
    }
    ~String()
    {
        if(_str)
        {
            delete[]_str;
        }
    }
private:
    char*_str;
};
voidTestString()
{
    Strings1("hello world!");
    Strings2=s1;
}

这里写图片描述

当类里面有指针对象时,进行简单赋值的浅拷贝,两个对象指向同一块内存,存在崩溃的问题!
这里我们要进行深拷贝。
  • 深拷贝及String类的深浅拷贝实现(简单模拟string)
    这里写图片描述
  • 简单模拟String实现
#include <iostream>
#include <string.h>
using namespace std;

class String{
    //浅拷贝
public:
    String(const char* str = "")//1.构造
        :_str(new char[strlen(str)+1])
    {
        strcpy(_str,str);
    }
    //String(const String& s)//2.拷贝构造
    //  :_str(s._str)
    //{}
        //深拷贝:传统写法
        String(const String& s)
            :_str(new char[strlen(s._str) + 1])
        {
            strcpy(_str,s._str);
        }
    //  //深拷贝:现代写法
    //  String(const String& s)
    //      :_str(NULL)
    //  {
    //      String tmp(s._str);
    //      swap(_str,tmp._str); 
    //  }
      /*String& operator=(const String& s)
      {
          if (&s != this)
          {
              String tmp(s._str);
              swap(_str, tmp._str);
          }
          return *this;
      }*/
    String& operator=(const String& s)//3.赋值构造
    {
        if (&s != this)
        {
            char *str = new char[strlen(s._str) + 1];
            strcpy(str, s._str);
            delete[] _str;
            _str = str;
        }
        return *this;
    }
    const char* c_str()
    {
        return _str;
    }
    char& operator[](size_t pos)//下标运算符重载
    {
        return _str[pos];
    }

    ~String()//4.析构函数
    {
        if (_str != nullptr)
        {
            delete[] _str;
        }
    }
private:
    char* _str;
};

namespace COW  //copy on write
{

    class String{
        //写时拷贝: 经典写法
    public:
        String(const char* str = "")
            :_str(new char[strlen(str) + 1])
            , _pCount(new int(1))
        {
            strcpy(_str, str);
        }
        String(const String& s)
            :_str(s._str)
            , _pCount(s._pCount)
        {
            (*_pCount)++;
        }

        void CopyOnWrite()
        {
            if (*_pCount > 1)
            {
                char* newStr = new char[strlen(_str) + 1];
                strcpy(newStr, _str);
                _str = newStr;

                --(*_pCount);
                _pCount = new int(1);
            }
        }
        void Release()
        {
            if (--(*_pCount) == 0)
            {
                delete[] _str;
                delete _pCount;

                _str = NULL;
                _pCount = NULL;
            }
        }


        const char& operator[](size_t pos) const
        {
            return _str[pos];
        }
        char& operator[](size_t pos)
        {
            CopyOnWrite();
            return _str[pos];
        }
        ~String()
        {
            Release();
        }

    private:
        char* _str;
        int* _pCount;//引用计数
    };
}

int main(void)
{
    String s1("change world");
    String s2(s1);

    cout<<s2.PushBack('!');
    cout<<s2.PushBack("I am Coming");
    cout<<s1 += "I am Coming";
    cout<<s1 += '!';

    return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值