c++day4

写出三种构造函数,算术运算符、关系运算符、逻辑运算符重载尝

cpp 复制代码
#include <iostream>
#include <cstring>
 
using namespace std;
 
class My_string
{
    private:
        char *data;
        int size;
 
    public:
        //无参构造默认长度为15
        My_string();
 
        //有参构造
        My_string(const char *str);
 
        My_string(int n, char ch);
 
        //析构函数
        ~My_string();
 
        //拷贝构造函数
        My_string(const My_string &other);
 
        //拷贝赋值函数
        My_string & operator=(const My_string &other);
 
        //c_str函数
        const char *c_str();
 
        //size函数
        int size_t();
 
        //empty函数
        bool empty();
 
        //at函数
        char at(int i);
 
        // + 运算符
        const My_string operator+(const My_string &R)const;
        //实现+=运算符重载
        const My_string operator+=(const My_string &R)const;
        // == 运算符
        bool operator==(const My_string &R)const;
        //实现[]运算符重载
        char &operator[](int n);
 
        friend ostream &operator<<(ostream &L, const My_string &R); //输入
        friend istream &operator>>(istream &L, const My_string &R); //输出
 
};
 
//无参构造默认长度为15
My_string::My_string():size(15)
{
    data = new char[size];
    data[0] = '\0';
}
 
//有参构造
My_string::My_string(const char *str)
{
    int s = strlen(str);
    data = new char[s+1];
    data[0] = '\0';
 
    strcpy(data, str);
}
 
My_string::My_string(int n, char ch)
{
    data = new char[n+1];
    data[0] = '\0';
 
    for(int i=0; i<n; i++) {
        this->data[i] = ch;
    }
    data[n+1] = '\0';
}
 
//析构函数
My_string::~My_string()
{
    delete []data;
    data = nullptr;
    cout<<"析构函数:this = "<<this<<endl;
}
 
//拷贝构造函数
My_string::My_string(const My_string &other)
{
    int s = strlen(other.data);
    data = new char[s+1];
    data[0] = '\0';
 
    strcpy(this->data, other.data);
}
 
//拷贝赋值函数
My_string & My_string::operator=(const My_string &other)
{
    int s = strlen(other.data);
    data = new char[s+1];
    data[0] = '\0';
 
    strcpy(this->data, other.data);
    return *this;
}
 
//c_str函数
const char* My_string::c_str()
{
    return data;
}
 
//size函数
int My_string::size_t()
{
    return strlen(data);
}
 
//empty函数
bool My_string::empty()
{
    return strlen(data)==0?1:0;
}
 
//at函数
char My_string::at(int i)
{
    return data[i];
}
 
//实现+运算符重载
const My_string My_string::operator+(const My_string &R)const
{
    My_string temp;
    strcat(temp.data, this->data);
    strcat(temp.data, R.data);
    return temp;
}
 
//实现+=运算符重载
const My_string My_string::operator+=(const My_string &R)const
{
    strcat(this->data, R.data);
    return this->data;
}
 
//实现[]运算符重载
char & My_string::operator[](int n)
{
    return data[n];
}
 
//实现==运算符重载
bool My_string::operator==(const My_string &R)const
{
    return this->data == R.data;
}
 
//实现插入运算符的重载:
ostream &operator<<(ostream &L, const My_string &R)
{
    L<<R.data;
    return L;
}
 
//实现提取运算符的重载:
istream &operator>>(istream &L, const My_string &R)
{
    L>>R.data;
    return L;
}
 
int main()
{
    My_string s1;   //无参构造
 
    My_string s2 = "hello world!";  //有参构造
    cout<<"s2 = "<<s2<<endl;
 
    My_string s3(5,'A');
    cout<<"s3 = "<<s3<<endl;
 
    My_string s4 = s2;  //拷贝构造
    cout<<"s4 = "<<s4<<endl;
 
    s1 = s2;            //拷贝赋值
    cout<<"s1 = "<<s1<<endl;
 
    printf("%s\n", s3.c_str());
    //cout<<s3.c_str()<<endl;
 
    cout<<"size_t = "<<s2.size_t()<<endl;
 
    My_string ss1;
    if(ss1.empty()) {
        cout<<"空字符串!"<<endl;
    }
    else {
        cout<<"非空字符串!"<<endl;
    }
 
    cout<<"s1.at(1) = "<<s1.at(1)<<endl;
    cout<<"s1[1] = "<<s1[1]<<endl;
 
    My_string ss2 = s2 + "  zhengqi";
    cout<<"ss2 = "<<ss2<<endl;
 
    My_string ss3;
    cout<<"请输入ss3字符串>>>";
    cin>>ss3;           //输入运算符
    cout<<"ss3 = "<<ss3<<endl;
 
    My_string ss4 = "aaa";
    My_string ss5 = "aaa";
    bool bo = ss4 == ss5;
    cout<<"bool = "<<bo<<endl;
 
    s1 += s3;
    cout<<s1<<endl;
 
    return 0;
}

试实现自增、自减运算符的重载

相关推荐
ZZZ_O^O20 分钟前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King43 分钟前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家1 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain1 小时前
算法 | 位运算(哈希思想)
算法
吾爱星辰2 小时前
Kotlin 处理字符串和正则表达式(二十一)
java·开发语言·jvm·正则表达式·kotlin
ChinaDragonDreamer2 小时前
Kotlin:2.0.20 的新特性
android·开发语言·kotlin
IT良2 小时前
c#增删改查 (数据操作的基础)
开发语言·c#
小飞猪Jay3 小时前
C++面试速通宝典——13
jvm·c++·面试
Kalika0-03 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
_.Switch3 小时前
Python Web 应用中的 API 网关集成与优化
开发语言·前端·后端·python·架构·log4j