string类的模拟实现
创始人
2024-03-13 08:22:29
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];}};
}

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...