c++day4

仿照string类,完成myString 类

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)          //string  s("hello world")
        {
            size = strlen(s);
             str = new char[size+1];
             strcpy(str, s);
        }
        //拷贝构造
        myString(const myString &other):str(new char(*(other.str))),size(other.size)
        {
            strcpy(this->str,other.str);
            this->size=other.size;
            cout<<"拷贝构造函数"<<endl;
        }
        //析构函数
        ~myString()
        {
            delete str;
            cout<<"析构函数:"<<this<<endl;

        }
        //拷贝赋值函数
        myString & operator=(const myString &other)
        {
            if(this != &other)          //确定不是自己给自己赋值
            {
                this->size = other.size;

                //判断原来指针空间释放被清空
                if(this->str != NULL)
                {
                    delete this->str;
                }
                this->str = new char(*other.str);

            }
            cout<<"拷贝赋值函数"<<endl;
            return  *this;             //返回自身引用
        }
        //判空函数
        bool empty()
        {
            return 0==size;
        }
        //size函数
        int mystring_size()
        {
            return strlen(str);
        }
        //c_str函数
        char *c_str()
        {
            return this->str;
        }
        //at函数
        char &at(int pos)
        {
            return str[pos-1];
        }
        //加号运算符重载
        const myString operator+(const myString &R)
        {
            myString c;
                // 计算合并后的字符串长度
            c.size=this->size+R.size;
            // 复制第一个字符串到结果字符串
            memcpy(c.str,this->str,this->size);
            // 复制第二个字符串到结果字符串
            memcpy(c.str+this->size,R.str,R.size+1);
            return c;
        }
        //加等于运算符重载
        myString & operator+=(const myString &R)
        {
            // 复制第二个字符串到第一个字符串后
            memcpy(this->str+this->size,R.str,R.size+1);
            // 计算合并后的字符串长度
            this->size=this->size+R.size;
            return *this;
        }
        //关系运算符重载(>)
        bool operator>(const myString &R)const
        {
            return strcmp(this->str,R.str)>0;
        }
        //中括号运算符重载
        char & operator[](int index)
        {
            return this->str[index];
        }
};

int main()
{

    myString s1("hello");
    //判空函数
    if(s1.empty())
    {
        cout<<"函数为空"<<endl;
    }
    else
    {
        cout<<"函数不为空"<<endl;
    }
    //打印s1的长度
    cout<<"size="<<s1.mystring_size()<<endl;
    //打印s1字符串内容
    cout<<"s1="<<s1.c_str()<<endl;
    //调用&at函数,打印s1[1]的内容
    cout<<"s1[1]="<<s1.at(2)<<endl;
    myString s2("world");
    //打印s2字符串内容
    cout<<"s2="<<s2.c_str()<<endl;
    //调用+=运算符重载函数
    s2+=s1;
    //打印更新之后s2的字符串内容
    cout<<"s2="<<s2.c_str()<<endl;
    //调用+号运算符重载
    myString s3=s1+s2;
    //打印s3字符串内容
    cout<<"s3="<<s3.c_str()<<endl;
    //调用[]运算符重载
    cout<<"s3[5]="<<s3[6]<<endl;
    return 0;
}
相关推荐
JieE21214 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架