day 0912

cpp 复制代码
#include <iostream>
#include <cstring>

using namespace std;
class myString
{
private:
    char *str;  //记录c风格的字符串
    int size;   //记录字符串的实际长度
public:
    //无参构造
    myString():size(10)
    {
        str = new char[size];   //构造一个长度为10的字符串
        strcpy(str," ");         //赋值为空串
    }
    //有参构造
    myString(const char *s)
    {
        size = strlen(s);
        str =new char[size+1];
        strcpy(str,s);
    }
    //拷贝构造
    myString(const myString &other)
    {
        size = strlen(other.str);
        str =new char[size+1];
        strcpy(str,other.str);
    }
    //析构函数
    ~myString ()
    {
        delete str;
        str = nullptr;
    }
    //拷贝赋值函数
    myString & operator=(const myString &other)
    {
        if(this != &other)
        {
            if(this->str != NULL)
            {
                delete str;
            }
            this->str = new char[strlen(other.str)+1];
            strcpy(str,other.str);
        }
        return *this;
    }
    //判空函数
    bool str_empty()
    {
        return str == nullptr;
    }
    //size函数
    int str_size()
    {
        return size;
    }
    //c_str函数
       char *c_str()
       {
           char *c_string = new char[size +1];
           strcpy(c_string, str);
           return c_string;
       }
    //at函数
    char &at(int pos)
    {
        if(pos<0||pos>size-1)
            return*str;
            return *(str+pos);
    }
    //加号运算符重载
    const myString operator+(const myString &s)
    {
        myString  tmp;
        tmp.size = size + s.size;
        tmp.str = new char[tmp.size+1];
        strcpy(tmp.str,str);
        char *dstr = tmp.str + size;
        strcpy(dstr, s.str);
        dstr = nullptr;
        return tmp;
    }
    //加等于运算符重载
    const myString operator+=(const myString &s)
    {
        myString tmp(*this);
        size = tmp.size + s.size;
        delete str;
        str = new char[size+1];
        strcpy(str,tmp.str);
        char *dstr = str + tmp.size;
        strcpy(dstr, s.str);
        dstr = nullptr;
        return *this;
    }
    //关系运算符重载(>)
    bool operator >(const myString &s)
    {
        int i=0;
        for(;(*(str+i)==*(s.str+i) && *(str+i)!=0 && *(s.str+i)!=0);i++);
        return *(str+i)-*(s.str+i)>0;
    }
    //中括号运算符重载
    char &operator[](int pos)
    {
        if(pos<0||pos>size-1)
            return *str;
        return *(str+pos);
    }
    //定义成员函数
    void show()
    {
        cout<<str<<endl;
    }
};

int main()
{
   myString s1("hello ");
   myString s2("world");
   myString s3;
   s3 = s1+s2;
   s3.show();

   myString s4;
   s4 = s3;
   s4.show();

   s1+=s2;
   s1.show();

   s1[0]='H';
   s1.show();

   s1.at(6)='W';
   s1.show();
   return 0;
}
相关推荐
澄澈天空1 小时前
C++ MFC添加RichEditControl控件后,程序启动失败
c++·mfc
Lzc7742 小时前
C++初阶——简单实现vector
c++·简单实现vector
一个小白12 小时前
C++——list模拟实现
开发语言·c++
程序员老舅2 小时前
C++ Qt项目教程:WebServer网络测试工具
c++·qt·测试工具·webserver·qt项目·qt项目实战
靡不有初1113 小时前
CCF-CSP第18次认证第一题——报数【两个与string相关的函数的使用】
c++·学习·ccfcsp
cookies_s_s4 小时前
Linux--进程(进程虚拟地址空间、页表、进程控制、实现简易shell)
linux·运维·服务器·数据结构·c++·算法·哈希算法
不想编程小谭5 小时前
力扣LeetCode: 2506 统计相似字符串对的数目
c++·算法·leetcode
曼巴UE56 小时前
UE5.3 C++ TArray系列(一)
开发语言·c++·ue5
阿巴~阿巴~6 小时前
多源 BFS 算法详解:从原理到实现,高效解决多源最短路问题
开发语言·数据结构·c++·算法·宽度优先
CoderCodingNo7 小时前
【GESP】C++二级真题 luogu-b3924, [GESP202312 二级] 小杨的H字矩阵
java·c++·矩阵