string类的实现终极版

本文介绍了一种写时拷贝(Copy-On-Write, COW)技术的具体实现方式,通过C++示例代码展示如何在自定义字符串类中应用COW来优化内存使用效率和减少不必要的内存拷贝。

写时拷贝(COW)的实现:

#include<iostream>
#include<cassert>

using namespace std;

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

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

	~String()
	{
		if(_str!=NULL)
		{
			if(--(*(int*)(_str-4)))
			{
				delete[] (_str-4);
			}
		}
	}

	String& operator=(const String& str)
	{
		if(this!=&str)
		{
			if(--(*(int*)(_str-4)))
			{
				delete[] (_str-4);
			}
			_str=str._str;
			++(*(int*)(_str-4));
		}
		return *this;
	}

	char& operator[](int index)
	{
		assert(index>=0 && index<strlen(_str));
		_str[index]=*(_str+index);
		return _str[index];
	}

	friend ostream& operator<<(ostream& os,const String& str);


private:
	char *_str;
};

ostream& operator<<(ostream& os,const String& str)
{
	cout<<str._str<<endl;
	return os;
}

int main()
{
	//String s1("hello");
	String s2("abcdefg");
	cout<<s2;
	cout<<s2[0];
	getchar();
	//String s3=s2;
	//String s3(s2);
	return 0;
}


本文出自 “七月朔风” 博客,请务必保留此出处http://luminous.blog.51cto.com/10797288/1749228

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值