【C++】模拟String___引用计数写实拷贝

本文探讨了C++中如何模拟String对象的引用计数,并详细介绍了将引用计数存储为独立空间的方法,以及如何为字符串开辟额外的四个字节来存储引用计数的具体实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

> 1、引用计数作为独立的一块空间

#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
using namespace std;

#class String
{
public:
    String(char* str="")
        :_Refcount(new int(1))
    {
        _str = new char[strlen(str) + 1];
        _str = str;
        *(_Refcount) = 1;
    }

    String(String const& str)
        :_str(NULL)
    {
        _str = str._str;
        _Refcount=str._Refcount;
        (*(_Refcount)) += 1;
    }

    int& GetRefcount()
    {
        if ((*_Refcount) == 0)
        {
            delete[] _str;
            delete[] _Refcount;
            _str = NULL;
        }
        return *(_Refcount);
    }

    String& operator=(String const&str)
    {
        if (_str != str._str)
        {
            if (--GetRefcount() == 0)
            { 
                {
                    delete[] _str;
                    delete _Refcount;
                }
                _str = str._str;
                _Refcount = str._Refcount;
                GetRefcount()++;
            }

        }
    }



    ~String()
    {
        if (GetRefcount() != 0)
        {
            GetRefcount()--;
        }
    }

    char* GetStr()
    {
        return _str;
    }
private:
    char* _str;
    int* _Refcount;
};

void FunTest()
{
    String s1("hello world!");
    String s2(s1);
    cout << s1.GetStr() << endl;
    cout << s2.GetStr() << endl;

}

int main()
{
    FunTest();
    system("pause");
    return 0;
}

2、字符串开辟四个字节存储引用计数


#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
using namespace std;

class String
{
public:
    String(char* str)
        :_str(new char[strlen(str)+5])
    {
        (*((int*)_str)) = 1;
        _str = _str + 4;
        strcpy(_str, str);
    }

    String(String const &str)
        :_str(NULL)
    {
        _str = str._str;
        (*(((int*)_str) - 1))++;
    }

    String& operator=(String const&str)
    {
        if (_str != str._str)
        {
            if (--GetRefcount() == 0)
            {
                _str = str._str;
                ++GetRefcount();
            }
            _str = str._str;
            (*(((int*)_str) - 1))++;

        }
    }


    char* GetStr()
    {
        return _str;
    }

int& GetRefcount()
        {
            if ((*(((int*)_str) - 1)) == 0)
            {
                delete[] (_str-4);
            }
            return (*(((int*)_str) - 1));
        }

    ~String()
    {
        if (GetRefcount() != 0)
        {
            (*(((int*)_str) - 1))--;
        }
    }
private:

    char* _str;
};


void FunTest()
{
    String s1("hello world!");
    String s2(s1);
    cout << s1.GetStr() << endl;
    cout << s2.GetStr() << endl;

}
int main()
{
    FunTest();
    system("pause");
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值