C++——实现String类(写时拷贝)

< String.h>


#ifndef __STRING_H__
#define __STRING_H__

#include <iostream>
#include <assert.h>

class String
{
public:
    String(const char* str = "");     //构造函数

    String(const String& copy);       //拷贝构造

    ~String();                        //析构函数

    String& operator=(String assign); //赋值函数

    char& operator[](size_t pos);     //

    const char& operator[](size_t pos)const;

    char* c_str();                    //获取字符串首地址

    int* GetCount();                  //获取指向同一块空间类的个数

    void Release();                   //删除

    void CopyAtWrite();               //写时拷贝

private:
    char*  _str;
};

#endif;

< String.cpp >

#include "String.h"
using namespace std;

String::String(const char* str) //构造函数
{
    if (str == nullptr)  //传的地址是nullptr
    {
        _str = new char[5];
        _str += 4;
        *_str = '\0';
        *GetCount() = 0;
    }
    else
    {
        _str = new char[strlen(str) + 5];
        _str += 4;

        *GetCount() = 1;
        strcpy(_str, str);
    }
}

String::String(const String& copy) //拷贝构造函数
:_str(copy._str)
{
    (*GetCount())++;
}

String::~String()
{
    Release();
}

//s2 = s1
String& String::operator=(String assign)  //赋值函数
{
    if (_str != assign._str)  //防止给自己赋值
    {
        Release();  
        _str = assign._str;
        ++(*GetCount());
    }
    return *this;
}

char& String::operator[](size_t pos)
{
    CopyAtWrite();
    return _str[pos];
}

char* String::c_str()
{
    return _str;
}

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

int* String::GetCount() 
{
    return ((int*)(_str - 4));
}

void String::Release()
{
    if (--(*GetCount()) == 0)
    {
        delete[] GetCount();
        _str = nullptr;
    }
}

void String::CopyAtWrite()
{
    if (*GetCount() > 1)
    {
        (*GetCount())--;
        char* NewStr = new char[strlen(_str + 5)];
        strcpy(NewStr, _str);
        _str = NewStr + 4;
        *GetCount() = 1;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值