代码如下:

#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <assert.h>
#include <cstring>
using namespace std;class String
{public:String(const char *str = ""){assert(str != nullptr);_size = strlen(str);_str = new char[_size + 1];_capacity = _size;strcpy(_str, str);}String(const String &s) :_str(nullptr), _size(0), _capacity(0){String tmp(s._str);Swap(tmp);}void Swap(String &s){swap(_str, s._str);swap(_size, s._size);swap(_capacity, s._capacity);}String &operator=(String s){if (this != &s){Swap(s);}return *this;}~String(){if (_str != nullptr){delete[]_str;_str = nullptr;}}size_t size() const{return _size;}size_t capacity()const{return _capacity;}char &operator[](size_t pos){assert(pos < _size);return _str[pos];}const char &operator[](size_t pos) const{assert(pos < _size);return _str[pos];}typedef char *iterator;typedef const char *const_iterator;iterator begin(){return _str;}iterator end(){return _str + _size;}const_iterator begin()const{return _str;}const_iterator end()const{return _str + _size;}void reserve(size_t n){if (n > _capacity){char *tmp = new char[n + 1];strcpy(tmp, _str);delete[] _str;_str = tmp;_capacity = n;}}void push_back(const char &ch){if (_size == _capacity){size_t newCapcity = _capacity == 0 ? 15 : 2 * _capacity;reserve(newCapcity);}_str[_size++] = ch;_str[_size] = '\0';}void resize(size_t n, const char &ch = '\0'){if (n > _capacity){reserve(n);}if (n > _size)memset(_str + _size, ch, (n - _size) * sizeof(char));_size = n;_str[_size] = '\0';}void append(const char *str){int len = strlen(str);if (_size + len > _capacity){reserve(_size + len);}memcpy(_str + _size, str, sizeof(char)*len);_size += len;_str[_size] = '\0';}String &operator+=(const String &str){append(str._str);return *this;}String &operator+=(const char *str){append(str);return *this;}String &operator+=(const char ch){push_back(ch);return *this;}void insert(size_t pos, const char &ch){assert(pos <= _size);if (_size == _capacity){size_t newCapacity = _capacity == 0 ? 15 : 2 * _capacity;reserve(newCapacity);}size_t end = _size + 1;while (end > pos){_str[end] = _str[end - 1];--end;}_str[pos] = ch;++_size;}void insert(size_t pos, const char *str){assert(pos <= _size);int len = strlen(str);if (_size + len >= _capacity){reserve(_size + len);}size_t end = _size + len;while (end > pos + len - 1){_str[end] = _str[end - len];--end;}memcpy(_str + pos, str, sizeof(char)*len);_size += len;}void erase(size_t pos, size_t len){assert(pos < _size);if (pos + len >= _size){_size = pos;_str[_size] = '\0';}else{size_t start = pos + len;while (start <= _size){_str[pos++] = _str[start];++start;}_size -= len;}}size_t find(const char &ch, size_t pos = 0){assert(pos < _size);for (size_t i = pos; i < _size; i++){if (_str[i] == ch){return i;}}return npos;}size_t find(const char *str, size_t pos = 0){char *ptr = strstr(_str, str);if (ptr != nullptr){return ptr - _str;}return npos;}private:char *_str;size_t _size;size_t _capacity;static const size_t npos;
};const size_t String::npos = -1;String  operator+(const String &str1, const String &str2)
{String tmp = str1;tmp += str2;return tmp;
}String  operator+(const String &str1, const char *str2)
{String tmp = str1;tmp += str2;return tmp;
}String operator+(const char &ch, const String &str1)
{String tmp = str1;tmp += ch;return tmp;
}ostream &operator<<(ostream &out, const String &str)
{for (const auto &ch : str){cout << ch;}return out;
}istream &operator>>(istream &in, String &str)
{char ch;while (ch = getchar()){if (ch == ' ' || ch == '\n' || ch == '\t'){break;}str += ch;}return in;
}

测试代码如下:

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include "String.h"using namespace std;int main(){String str = ("Hello Wecccccccc");cout << str << endl;String str1 = str;cout << str1 << endl;for (int i = 0; i < str1.size(); i++){cout << str[i] << " ";}cout << endl;for (const auto&ch : str){cout << ch << " ";}cout << endl;String::iterator it = str.begin();while (it != str.end()){cout << *it << " ";it++;}cout << endl;cout << "str size = " << str.size() << " " << "str capacity = " << str.capacity() << endl;str.reserve(20);cout << "str size = " << str.size() << " " << "str capacity = " << str.capacity() << endl;str.push_back('N');str.push_back('N');str.push_back('N');str.push_back('N');str.push_back('N');cout << str << endl;String str3 = "Weccccc";str3.resize(3);cout << str3 << endl;str3.resize(5, 'a');cout << str3 << endl;str3.resize(10, 'b');cout << str3 << endl;str3.append(" hello");cout << str3 << endl;String str4 = "We";String str5 = "cccccccc";str4 += str5;cout << str4 << endl;cout << str4 + str5 << endl;String str6;str6 = 'W' + str4+"123";cout << str6 << endl;String str7 = "abc";str7.insert(0, '1');cout << str7 << endl;str7.insert(1, '2');cout << str7 << endl;str7.insert(5, "35");cout << str7 << endl;str7.erase(0, 2);cout << str7 << endl;str7.erase(4, 1);cout << str7 << endl;str7.erase(1, 2);cout << str7 << endl;int pos = str7.find('3');cout << pos << endl;pos = str7.find('b');cout << pos << endl;return 0;}

测试结果:

[C++STL]C++实现string容器相关推荐

  1. C++STL的string容器

    C++STL的string容器 string容器 string基本概念 string构造函数 string赋值操作 string字符串拼接 string查找和替换 string字符串比较 string ...

  2. C++ STL常用标准库容器入门(vector,map,set,string,list...)

    STL常用标准库容器 C++ STL中最基本以及最常用的类或容器无非就是以下几个: 目录 string vector deque list forward_list queue priority_qu ...

  3. C++练习笔记STL之string容器

    STL(Standard Template Library)标准模板库 STL从广义上分为容器(Container).算法(algorithm).迭代器(iterator) 容器和算法之间通过迭代器进 ...

  4. 【C++提高编程笔记】三.(一).STL常用容器之string容器

    文章目录 1.string基本概念 2.string构造函数 3.string赋值操作 4.string字符串拼接 5.string查找和替换 6.string字符串比较 7.string字符存取 8 ...

  5. STL中的set容器的一点总结

    1.关于set C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, string, list等方便的容器,更重要的是STL封装了许多复杂的数据结构算法和大量常用数据结构 ...

  6. C++ STL学习笔记(2) 容器结构与分类

    接着学习侯捷老师的C++ STL! 在使用容器的时候,需要明白容器中元素之间在内存里的关系是什么样的,是连续的,还是非连续的. 容器可以分为两类: 1. sequence container , 即序 ...

  7. STL库:string

    STL库:string 文章目录 STL库:string 1.STL库对于string类的介绍 2.string常用接口的掌握 2.1 string的构造接口 2.2 string的容量操作接口 2. ...

  8. STL 标准模板库—容器部分【C++】

    STL标准模板库 包含内容: 容器类:vector.list.deque.set.map等 迭代器:"泛型指针",每个容器都有自己的迭代器,[vector和deque的迭代器是随机 ...

  9. 学习笔记:C++初阶【C++入门、类和对象、C/C++内存管理、模板初阶、STL简介、string、vector、list、stack、queueu、模板进阶、C++的IO流】

    文章目录 前言 一.C++入门 1. C++关键字 2.命名空间 2.1 C语言缺点之一,没办法很好地解决命名冲突问题 2.2 C++提出了一个新语法--命名空间 2.2.1 命名空间概念 2.2.2 ...

最新文章

  1. 《自然语言处理入门》不是 NLP 学习路上的万能药
  2. MapPoint之旅(2)-----Getting Started with MapPoint Web Service(1)
  3. Sun副总裁:绿色数据中心需分四步走
  4. Vue中使用vue-video-player和videojs-flash插件实现播放rtmp视频文件流
  5. unix 网络编程卷2 第43页 管道:open竟然会阻塞?
  6. java poi读取word中附件_Java POI导入word, 带图片
  7. 有关《8zsb》的一些介绍
  8. 推荐系统 | 引用量超过1000的52篇经典论文
  9. python自动轨迹绘制_自动轨道图,轨迹,绘制
  10. Android 对ScrollView滚动监听,实现美团、大众点评的购买悬浮效果
  11. C# -- 使用FileInfo获取文件信息
  12. 百度官方wormHole后门检测记录(转)
  13. 算法 第四版 2.1.25 不需要交换的插入排序
  14. 网络编程——UDP编程
  15. Linux家目录被误删除恢复
  16. pygame学习笔记——飞机大战爆炸效果
  17. python span()函数_Python正则表达式六种函数实例讲解
  18. 邮箱客户端程序的实现
  19. 面对ONF挑衅 思科用ACI回绝SDN挑战
  20. JavaWeb【Mybatis】Mybatis的操作步骤

热门文章

  1. C#趣味程序---百鸡百钱
  2. Andriod之使用极光推送自定义消息打造个性的消息推送效果
  3. 【二】Windows API 零门槛编程指南——CreateWindow 窗口创建 “万字长篇专业术语全解”
  4. python数据分析软件_Python数据分析工具
  5. odbc mysql 配置文件_ODBC连接主流数据库的配置方法
  6. 跟你们讲一个鬼故事,TA回来了!
  7. OpenAI“单手解魔方”被公开质疑,Gary Marcus称七大问题涉嫌误导
  8. 每日一笑 | 终于知道为什么胖了之后气质会垮了
  9. 16个让你烧脑让你晕的悖论
  10. 主成分分析和因子分析十大不同点