当前位置: 首页 > news >正文

MyString字符串类

MyString字符串类

包括:有参构造、拷贝构造、移动构造、析构、拷贝赋值和移动赋值。

MyString.h文件

#ifndef MYSTRING_H
#define MYSTRING_H#include <iostream>
using namespace std;class MyString
{private:char* str;unsigned int MaxSize;unsigned int Length = 0;public:MyString() = default;              /*默认构造函数*/MyString(unsigned int m);          /*构造函数,空字符串*/MyString(const char* S);           /*构造函数,写入字符串*/MyString(const MyString& S);       /*拷贝构造函数*/MyString( MyString && S) noexcept; /*移动构造函数*/~MyString();                       /*析构函数*//*获取字符串长度*/unsigned int GetLength();/*字符串输出*/friend ostream& operator<< (ostream& Output, MyString& S);/*字符串输入*/friend  istream& operator>> (istream& Input, MyString& S);/*获取单个字符*/char & operator[] (unsigned int i);/*添加或修改单个字符*/void at(char ch);void at(unsigned int i, char ch);/*字符串比较*/bool operator== (MyString & S2);bool operator> (MyString & S2);bool operator< (MyString & S2);/*拷贝赋值运算符重载*/MyString& operator= (MyString& S);/*移动赋值运算符重载*/MyString& operator= (MyString&& S) noexcept;/*字符串链接函数*/MyString operator+ (MyString& S2);
};#endif

MyString.cpp文件

#include "MyString.h"/*构造函数,空字符串*/
MyString::MyString(unsigned int m) :MaxSize(m)
{MaxSize += 1;str = new char[MaxSize] {};str[MaxSize-1] = '\0';cout << "空构造函数:";
}
/*构造函数,写入字符串*/
MyString::MyString(const char* S)
{const char* p = S;while (*p != '\0'){p++;Length++;}MaxSize = Length + 1;str = new char[MaxSize] {};for (unsigned int i = 0; i < Length; i++){str[i] = S[i];}str[Length] = '\0';cout << "字符串构造函数:" ;
}
/*拷贝构造函数*/
MyString::MyString(const MyString& S)
{Length = S.Length;MaxSize = S.MaxSize;str = new char[MaxSize] {};for (unsigned int i = 0; i < MaxSize; i++){str[i] = S.str[i];}cout << "拷贝构造函数:";
}
/*移动构造函数*/
MyString::MyString(MyString&& S) noexcept
{Length = S.Length;MaxSize = S.MaxSize;str =S.str;S.str = nullptr;cout << "移动构造函数:";
}
/*析构函数*/
MyString::~MyString()
{delete[] str;cout << "析构函数" << endl;
}
/*返回字符串长度*/
unsigned int MyString::GetLength()
{return Length;
}
/*字符串输入*/
ostream& operator<< (ostream& Output, MyString& S)
{Output << S.str;return Output;
}
/*字符串输出*/
istream& operator>> (istream& Input, MyString& S)
{Input >> S.str;return Input;
}
/*获取单个字符*/
char & MyString::operator[] (unsigned int i)
{return str[i];
}
/*添加或修改单个字符*/
void  MyString::at(char ch)
{if (Length < MaxSize - 1)str[Length] = ch;Length++;
}
void MyString::at(unsigned int i, char ch)
{if( i < Length)str[i] = ch;
}
/*字符串比较函数*/
bool MyString::operator== (MyString & S2)
{char* str1 = str;char* str2 = S2.str;while (*str1 != '\0' || *str2 != '\0'){if (*str1 > *str2)return false;if (*str1 < *str2)return false;str1++;str2++;}return true;
}
bool MyString::operator> (MyString & S2)
{char* str1 = str;char* str2 = S2.str;while (*str1 != '\0' || *str2 != '\0'){if (*str1 > *str2)return true;if (*str1 < *str2)return false;str1++;str2++;}return false;
}
bool MyString::operator< (MyString & S2)
{char* str1 = str;char* str2 = S2.str;while (*str != '\0' || *str2 != '\0'){if (*str1 > *str2)return false;if (*str1 < *str2)return true;str1++;str2++;}return false;
}
/*赋值运算符重载*/
MyString & MyString::operator= (MyString& S)
{delete[] str;Length = S.Length;MaxSize = S.MaxSize;str = new char[MaxSize] {};for (unsigned int i = 0; i < MaxSize; i++){str[i] = S.str[i];}cout << "拷贝赋值运算符重载:";return *this;
}
/*移动赋值运算符重载*/
MyString& MyString::operator= (MyString&& S) noexcept
{delete[] str;Length = S.Length;MaxSize = S.MaxSize;str = S.str;S.str = nullptr;cout << "移动赋值运算符重载:";return *this;
}
/*字符串链接函数*/
MyString MyString::operator+ (MyString& S2)
{MaxSize += S2.MaxSize;char* temp = new char[MaxSize] {};for (unsigned int i = 0; i < Length; i++){temp[i] = str[i];}temp[Length] = ' ';Length += 1;for (unsigned int i = Length; i < MaxSize; i++){temp[i] = S2.str[i - Length];}Length += S2.Length;delete[]str;str = temp;return *this;
}

main.cpp测试:

#include <iostream>
using namespace std;#include "MyString.h"
MyString  GetString()
{//   MyString n =  "1234";
//    MyString m(2);MyString temp = "C++";return temp;
}
int main()
{MyString S1{ "Hello World!" };  //构造函数,字符串初始化cout << S1 <<' '<< S1.GetLength() << endl;MyString S2{ S1 } ;  //拷贝构造函数cout << S2 <<' '<< S2.GetLength() << endl;MyString S3{ 3 };   //构造函数,空字符串S3.at('A');S3.at('B');S3.at('C');cout << S3 <<' '<< S3.GetLength() << endl;S3[2] = 'Z';cout << S3[2] << endl;S1 =  S3;               /拷贝赋值cout << S1 << ' ' << S1.GetLength() << endl;cout << (S1 < S2) << endl;cout << (S1 > S2) << endl;cout << (S1 == S2) << endl;MyString S4{ move(S1) }; //移动构造函数cout << S4 << ' ' << S4.GetLength() << endl;S4 = GetString();      //移动赋值cout << S4 << ' ' << S4.GetLength() << endl;S4 = S2 + S3;cout << S4 << ' ' << S4.GetLength() << endl;
}

测试结果:

MyString

相关文章:

  • TOGAF(企业架构)
  • VSCode snippets
  • Android11系统桌面隐藏指定APP图标
  • nginx请求时找路径问题
  • NetSuite数据备份办法
  • Day 11 python学习笔记
  • Linux系统下配置王爽汇编语言环境
  • SQL注入原理及思路(mysql)
  • 【ChatGPT系列】ChatGPT:创新工具还是失业威胁?
  • 导入Embassy库进行爬虫
  • 上海高考英语科目命题趋势和备考建议,附1990-2023真题解析
  • 网络安全—小白自学
  • 磨人的Ts
  • java中的内存分配
  • mysql用户及权限管理(InsCode AI 创作助手)
  • Angular2开发踩坑系列-生产环境编译
  • classpath对获取配置文件的影响
  • eclipse的离线汉化
  • JavaScript中的对象个人分享
  • JSONP原理
  • JS函数式编程 数组部分风格 ES6版
  • Linux快速配置 VIM 实现语法高亮 补全 缩进等功能
  • Promise初体验
  • vue:响应原理
  • vue总结
  • 表单中readonly的input等标签,禁止光标进入(focus)的几种方式
  • 订阅Forge Viewer所有的事件
  • 飞驰在Mesos的涡轮引擎上
  • 诡异!React stopPropagation失灵
  • 讲清楚之javascript作用域
  • 面试总结JavaScript篇
  • 如何合理的规划jvm性能调优
  • 如何实现 font-size 的响应式
  • 腾讯大梁:DevOps最后一棒,有效构建海量运营的持续反馈能力
  • 写代码的正确姿势
  • 在Docker Swarm上部署Apache Storm:第1部分
  • media数据库操作,可以进行增删改查,实现回收站,隐私照片功能 SharedPreferences存储地址:
  • No resource identifier found for attribute,RxJava之zip操作符
  • ​Kaggle X光肺炎检测比赛第二名方案解析 | CVPR 2020 Workshop
  • ​七周四次课(5月9日)iptables filter表案例、iptables nat表应用
  • (30)数组元素和与数字和的绝对差
  • (TipsTricks)用客户端模板精简JavaScript代码
  • (六)软件测试分工
  • (数据结构)顺序表的定义
  • (图)IntelliTrace Tools 跟踪云端程序
  • (学习日记)2024.04.04:UCOSIII第三十二节:计数信号量实验
  • (一)【Jmeter】JDK及Jmeter的安装部署及简单配置
  • (原創) 如何讓IE7按第二次Ctrl + Tab時,回到原來的索引標籤? (Web) (IE) (OS) (Windows)...
  • (原創) 如何刪除Windows Live Writer留在本機的文章? (Web) (Windows Live Writer)
  • (转)ORM
  • (转)利用PHP的debug_backtrace函数,实现PHP文件权限管理、动态加载 【反射】...
  • (转)平衡树
  • (转)淘淘商城系列——使用Spring来管理Redis单机版和集群版
  • (转载)hibernate缓存
  • (最全解法)输入一个整数,输出该数二进制表示中1的个数。