模拟实现string深拷贝的两个版本

本文探讨了字符串类中深拷贝的两种实现方法:传统写法与现代写法。传统写法直接进行内存分配与复制;现代写法通过临时对象和交换技巧实现。文章详细展示了两种方法的具体代码实现。

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

我们在http://write.blog.csdn.net/postedit/68495670博客中描述了string类的深浅拷贝问题,现在我们了解深拷贝两个版本,一个是传统写法,另一个是现代写法。

1,传统写法:

#include<iostream>
using namespace std;
class Mystring
{
public:
	Mystring(char* str)//初始化
		:_str(new char[strlen(str) + 1])
	{
		strcpy(_str, str);
	}
	Mystring(const Mystring& s)//深拷贝构造
		:_str(new char[strlen(s._str) + 1])
	{
		strcpy(_str, s._str);
	}
	Mystring& operator=(const Mystring& s)//赋值运算符的重载
	{
		if (this != &s)//防止自己给自己赋值
		{
			delete[] _str;
			_str = new char[strlen(s._str) + 1];
			strcpy(_str, s._str);
		}
		return *this;
	}
	~Mystring()
	{
		delete[] _str;
		_str = NULL;
	}
protected:
	char _buffer[16];
	size_t _size;
	char* _str;
	size_t _capacity;
};
2,现代写法:

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>

using namespace std;
class Mystring
{
public:
	Mystring(char* str)
		:_str(new char[strlen(str) + 1])
	{
		strcpy(_str, str);
	}
	Mystring(const Mystring& s)//拷贝构造
		:_str(NULL)
	{
		Mystring tmp(s._str);
		swap(_str, tmp._str);
	}
	Mystring& operator=(const Mystring& s)
	{
		if (this != &s)
		{
			Mystring tmp(s._str);
			swap(_str, tmp._str);
		}
		return *this;
	}
	~Mystring()
	{
		delete[] _str;
		_str = NULL;
	}
protected:
	char _buffer[16];
	size_t _size;
	char* _str;
	size_t _capacity;
};



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值