string类的模拟实现
创始人
2024-04-16 01:19:39
0

目录

一、浅拷贝、深拷贝

 二、传统版本写法的String类

三、现代版本写法的String类

四、String类的模拟实现


一、浅拷贝、深拷贝

构造

	//构造函数String(const char* str = ""){if (nullptr == str){assert(false);return;}_str = new char[strlen(str) + 1];strcpy(_str, str);}

析构

	//析构函数~String(){if (_str){delete[] _str;_str = nullptr;}}

代码展示:

#define _CRT_SECURE_NO_WARNINGS
#include
using namespace std;
#include
#include
//构造
//拷贝构造
//赋值运算符重载
//析构函数
class String
{
public://构造函数String(const char* str = ""){if (nullptr == str){assert(false);return;}_str = new char[strlen(str) + 1];strcpy(_str, str);}//析构函数~String(){if (_str){delete[] _str;_str = nullptr;}}
private:char* _str;
};
void TestString()
{String s1("hello sunlang!");String s2(s1);cout << s1 << endl;cout << s2 << endl;
}
int main()
{TestString();return 0;
}

 浅拷贝:编译器合成默认的拷贝构造,导致s1,s2共用同一块内存空间,在释放时同一块空间被释放多次而引起程序崩溃。

深拷贝:每个对象都有一份独立的资源,涉及到资源的管理,其拷贝构造函数、赋值运算符重载以及析构函数必须要显示给出。

 二、传统版本写法的String类

//传统版本写法的String类
class String
{
public://构造String(const char* str = ""){if (nullptr == str){assert(false);return;}_str = new char[strlen(str) + 1];strcpy(_str, str);}//拷贝构造String(const String& s):_str(new char[strlen(s._str) + 1]){strcpy(_str, s._str);}//赋值重载String& operator=(const String& s){if (this != &s){char* pStr = new char[strlen(s._str) + 1];strcpy(pStr, s._str);delete[] _str;_str = pStr;}return *this;}//析构~String(){if (_str){delete[] _str;_str = nullptr;}}
private:char* _str;
};

三、现代版本写法的String类

#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
using namespace std;
class String
{
public://构造String(const char* str = ""){if (nullptr == str){assert(false);return;}_str = new char[strlen(str) + 1];strcpy(_str, str);}//拷贝构造String(const String& s):_str(nullptr){String strTmp(s._str);swap(_str, strTmp._str);}//赋值重载String& operator=(String s){swap(_str, s._str);return *this;}~String(){if (_str){delete[] _str;_str = nullptr;}}
private:char* _str;
};

四、String类的模拟实现

#define _CRT_SECURE_NO_WARNINGS
#include
using namespace std;
#include
namespace sunlang
{class string{public:typedef char* iterator;public://构造string(const char* str = ""){_size = strlen(str);_capacity = _size;_str = new char[_capacity + 1];strcpy(_str, str);}//拷贝构造string(const string& s):_str(nullptr), _size(0), _capacity(0){string tmp(s._str);this->swap(tmp);}//赋值重载string& operator=(string s){this->swap(s);return *this;}//析构~string(){if (_str){delete[] _str;_str = nullptr;}}//iteratoriterator begin(){return _str;}iterator end(){return _str + _size;}//modifyvoid push_back(char c){if (_size == _capacity){reverse(_capacity * 2);}_str[_size++] = c;_str[_size] = '\0';}string& operator+=(char c){push_back(c);return *this;}void clear(){_size = 0;_str[_size] = '\0';}void swap(string& s){std::swap(_str, s._str);std::swap(_size, s._size);std::swap(_capacity, s._capacity);}const char* c_str()const{return _str;}//capacitysize_t size()const{return _size;}size_t capacity()const{return _capacity;}bool empty()const{return 0 == _size;}void resize(size_t newSize, char c = '\0'){if (newSize > _size){if (newSize > _capacity){reserve(newSize);}memset(_str + _size, c, newSize - _size);}_size = newSize;_str[newSize] = '\0';}void reverse(size_t newCapacity){if (newCapacity > _capacity){char* str = new char[newCapacity + 1];strcpy(str, _str);delete[]_str;_str = str;_capacity = newCapacity;}}//accesschar& operator[](size_t index){assert(index < _size);return _str[index];}const char& operator[](size_t index)const{assert(index < _size);return _str[index];}};
}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...