C++重载实现Mystring

news2024/11/11 7:23:01

#include<iostream>
#include<cstring>        //可以使用string类
#include<string>       //#include <string.h>

using namespace std;

class Mystring
{
    public:
        Mystring():str(nullptr), len(0){
        }

        Mystring(const char *const str1)
        {
            if (str1)
            {
                len = strlen(str1);
                str = new char[len + 1]; 
                strcpy(str, str1);
            }
            else
            {
                str = nullptr;
                len = 0;
            }
        }

        ~Mystring()
        {
            delete[] str;
        }
                                                                     
        //  拷贝构造函数  
        Mystring(const Mystring &other)
        {
            len =other.len;
            str = new char[len+1];
            strcpy(str, other.str);
        }

        //拷贝赋值函数 
        Mystring& operator=(const Mystring& other)
        {
            if(&other != this)
            {
                if(str != nullptr)
                {
                    delete []str;
                    str = nullptr;
                }
				len = other.len;
                str = new char[len+1];
                strcpy(str, other.str);
            }

            return *this;
        }

        //data()
        char* data()
        {
            return str;
        }

        //size()
        int size()
        {
            return len;
        }

        //empty()
        bool empty()
        {
            return 0==len;
        }

        //at()
        char& at(int index)
        {
            if(index<0 || index>=len)
            {
                cout << index <<"位置越界" << endl;
                return str[0];
            }

            return str[index];      //*(str+index)
        }
		
		//拼接
		Mystring operator+(const Mystring& R) const
		{
			Mystring s;
			s.len = R.len+len;
			s.str=new char[s.len+1];
			strcpy(s.str,str);
			strcat(s.str,R.str);
			return s;
		}
		
		//两侧字符串不相等
		bool operator!=(const Mystring& R) const
		{
			return strcmp(str,R.str)!=0;
		}
		
		//两侧字符串相等
		bool operator==(const Mystring& R) const
		{
			return strcmp(str,R.str)==0;
		}
		
		//一侧字符串小于另一侧
		bool operator<(const Mystring& R) const
		{
			return strcmp(str,R.str)<0;
		}
		
		//一侧字符串小于等于另一侧
		bool operator<=(const Mystring& R) const
		{
			return strcmp(str,R.str)<=0;
		}
		
		//一侧字符串大于另一侧
		bool operator>(const Mystring& R) const
		{
			return strcmp(str,R.str)>0;
		}
		
		//一侧字符串大于等于另一侧
		bool operator>=(const Mystring& R) const
		{
			return strcmp(str,R.str)>=0;
		}
		
		
	friend istream& operator>>(istream& L,Mystring& R);
	friend ostream& operator<<(ostream& L,const Mystring& R);

    private:
        int len;
        char *str;
};

//重载<<
ostream& operator<<(ostream& L,const Mystring& R)
{
	L<<R.str;
	return L;
}

//重载>>
istream& operator>>(istream& L,Mystring& R)
{
	char buf[100];	
	L>>buf;
	R=Mystring(buf);
	return L;
}




int main(int argc,const char* argv[])
{
	Mystring str("ni hao");
	
	//字符串拼接
	Mystring str1;
	str1=str+" wen jie";
	cout<<"str1="<<str1<<endl;     
	
	//两侧字符串不相等
	Mystring str2("keli");
	bool res0 = str2 != str;
	cout<<"res0="<<res0<<endl;      
	
	//两侧字符串相等
	Mystring str3("ycd");
	bool res1 = str3 == "ycd";
	cout<<"res1="<<res1<<endl; 
	
	//一侧字符串小于另一侧
	Mystring str4("ycdab");
	bool res2 = str4 < "ycdab";
	cout<<"res2="<<res2<<endl; 
	
	//一侧字符串小于等于另一侧
	Mystring str5("ycdab");
	bool res3 = str5 <= "ycdab";
	cout<<"res3="<<res3<<endl; 
	
	//一侧字符串大于另一侧
	Mystring str6("ycdabe");
	bool res4 = str6 > "ycdab";
	cout<<"res4="<<res4<<endl; 
	
	//一侧字符串大于等于另一侧
	Mystring str7("ycdab");
	bool res5 = str7 >= "ycdab";
	cout<<"res5="<<res5<<endl; 
	
	Mystring str8;
	cout<<"请输入一个字符串"<<endl;
	cin>>str8;
	cout<<"str8="<<str8<<endl;
	
	
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2103107.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Datawhale X 李宏毅苹果书AI夏令营 学习笔记

学习日志 日期&#xff1a; 2024年9月3日 今日学习内容&#xff1a; 今天&#xff0c;我深入学习了深度学习中的几种重要概念&#xff0c;包括优化算法、特征归一化、以及批量归一化的原理和应用。这次学习的内容涵盖了从基础的梯度下降法到更高级的优化技术&#xff0c;同时…

【Linux系统编程】TCP实现--socket

使用套接字socket实现服务器和客户端之间的TCP通信。 流程如下&#xff1a; 实现代码&#xff1a; /* server.c */ #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <arpa/inet.h> #include <s…

分类预测|基于麻雀优化正则化极限学习机的数据分类预测Matlab程序SSA-RELM 多特征输入多类别输出

分类预测|基于麻雀优化正则化极限学习机的数据分类预测Matlab程序SSA-RELM 多特征输入多类别输出 文章目录 一、基本原理1. 数据准备2. RELM模型建立3. SSA优化RELM参数4. 模型训练5. 模型评估6. 结果分析与应用原理总结 二、实验结果三、核心代码四、代码获取五、总结 分类预测…

在Ubuntu上运行QtCreator相关程序

背景&#xff1a;希望尝试在Linux系统上跑一下使用QtCreator相关的程序&#xff0c;因为有一些工作岗位要求有Linux上使用Qt的经验。 (1)我是把Windows上的程序移过来的&#xff0c;Windows上文件名称是不区分大小写的。 而Ubuntu上是区分的 所以一部分头文件需要进行修改&am…

大数据Flink(一百一十二):Flink SQL作业快速入门

文章目录 Flink SQL作业快速入门 一、进入Flink开发平台 二、​​​​​​​创建作业 三、​​​​​​​​​​​​​​编写作业代码 四、​​​​​​​​​​​​​​进行更多配置 五、​​​​​​​​​​​​​​进行深度检查 六、​​​​​​​​​​​​​​进…

AWS SES服务 Golang接入教程(排坑版)

因为刚来看的时候 也迷迷糊糊的 所以 先讲概念 再上代码 一 基础设置 这里需要完成两个最基础的设置任务 1 是验证至少一个收件电子邮箱 2 【很关键】是验证发送域。即身份里的域类型的身份。&#xff08;可以理解为配置你的域名邮箱服务器&#xff08;SMPT&#xff09;为亚马…

PMP–一、二、三模、冲刺、必刷–分类–14.敏捷–技巧--累积流图

文章目录 技巧一模二模三模14.敏捷–敏捷团队的衡量结果–累积流图&#xff1a;1、 敏捷项目的项目经理担心团队在最近的迭代中失去了动力。项目经理应该使用哪两种工具来分析团队绩效&#xff1f;&#xff08;选择两个&#xff09; 冲刺必刷7.成本管理--挣值分析燃尽图仅能了解…

Trm理论 3(ELMo)

LSTM模型 如图&#xff0c;LSTM模型是rnn模型的改良版&#xff0c;通过ft来选择性的保留上一次得到的信息 ELMo模型&#xff08;双向LSTM&#xff09; ELMo模型是对word2vec的改良&#xff0c;改良了word2vec的二义性 对比上下两图&#xff0c;可以发现&#xff0c;WE对预测…

基于约束大于规范的想法,封装缓存组件

架构&#xff1f;何谓架构&#xff1f;好像并没有一个准确的概念。以前我觉得架构就是搭出一套完美的框架&#xff0c;可以让其他开发人员减少不必要的代码开发量&#xff1b;可以完美地实现高内聚低耦合的准则;可以尽可能地实现用最少的硬件资源&#xff0c;实现最高的程序效率…

Linux文件【系统调用接口及进程中对打开文件的管理操作】详细讲解

目录 一、open函数 1.介绍 2.open函数返回值 二、重定向 1.文件描述符的分配规则 2.重定向的本质 3.dup2系统调用 三、C语言库函数中的缓冲区及不同刷新模式 前言&#xff1a; 我们先来简单回顾一下C语言中的文件相关知识 ● 打开文件的方式 r …

数图亮相第三届中国区域零售创新峰会:共绘零售新蓝图,携手迈向新征程

8月31日&#xff0c;备受瞩目的第三届中国区域零售创新峰会在历史悠久的湖北襄阳圆满落下帷幕。在这场零售行业的盛会上&#xff0c;数图信息科技作为重要参会企业&#xff0c;积极参与其中&#xff0c;与众多行业精英共聚一堂&#xff0c;共同擘画零售业的宏伟蓝图。以下是本次…

C程序设计——指针杂谈0

变量和常量讲的差不多了&#xff0c;这里先把指针再深入理解一下&#xff0c;如果你是C语言初学者&#xff0c;本节可能看不太懂&#xff0c;没关系可以以后再看。 变量 当定义变量的时候&#xff0c;本质是在内存中分配了一段空间&#xff0c;这段空间的大小与变量的类型相关…

GD - EmbeddedBuilder - 给已有工程换MCU

文章目录 GD - EmbeddedBuilder - 给已有工程换MCU概述不行的重现 笔记工程的.gdc文件内容中有MCU型号可以改 给已有工程换MCU的使用场景END GD - EmbeddedBuilder - 给已有工程换MCU 概述 一个现存的EmbeddedBuilder的工程&#xff0c;想换个MCU配置做实验&#xff0c;又不想…

极盾故事|某金融租赁机构应用数据保护新策略:“动态脱敏”“二次授权”

数据的流通使用是创新的动力&#xff0c;但安全和合规是不可逾越的底线。企业如何在这三者之间找到平衡点&#xff1f; 极盾科技&#xff0c;助力某金融租赁机构&#xff0c;基于极盾觅踪构建应用数据动态脱敏系统&#xff0c;实现10&#xff0b;核心应用系统的统一管理&#x…

库(Library)

库的定义 在Linux操作系统中&#xff0c;库&#xff08;Library&#xff09;是一段编译好的、可重用的代码&#xff0c;它能够被其他程序或应用程序在运行时调用。库可以提高代码的模块化&#xff0c;使得开发者可以共享和重用代码&#xff0c;从而提高开发效率&#xff0c;减少…

如何在 Ubuntu 24.04 上安装 MariaDB ?

MariaDB 是一个流行的开源关系数据库管理系统&#xff0c;它是 MySQL 的一个分支&#xff0c;它被广泛用于存储和管理数据。本指南将引导您完成在 Ubuntu 24.04 上安装 MariaDB 的步骤。 Step 1: Update Your System 首先更新系统&#xff0c;确保所有的软件都是最新的。 su…

PMP–一、二、三模、冲刺、必刷–分类–14.敏捷–技巧–刺探

文章目录 技巧一模反例不选“刺探”14.敏捷--流程&#xff1a;&#xff08;2&#xff09;每日站会&#xff08;15分钟、轮流开、提出问题、不解决问题&#xff09;&#xff1a;输入任务板/看板 → 输出任务板更新、燃尽图更新、障碍日志、产品增量&#xff1b;14.敏捷--方法--每…

树莓派扩展RGB点阵屏的使用

本篇来介绍一个树莓派的RGB 8x8点阵屏扩展板的使用。 1 RGB点阵屏 这里使用SunFounder的一个RGB 8x8树莓派扩展板&#xff0c;将其插接到树莓派中即可使用。 2 树莓派IIC配置 树莓派系统的安装&#xff0c;可参考之前的文章&#xff1a; 这个RGB点阵屏与树莓派直接使用IIC通…

Opencv中的直方图(2)计算图像的直方图函数calcHist()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 计算一组数组的直方图。 函数 cv::calcHist 计算一个或多个数组的直方图。用于递增直方图bin的元组的元素是从相同位置的相应输入数组中获取的。…

C++设计模式——Template Method模板方法模式

一&#xff0c;模板方法模式的定义 模板方法模式是一种行为型设计模式&#xff0c;它先定义了一个算法的大致框架&#xff0c;然后将算法的具体实现步骤分解到多个子类中。 模板方法模式为算法设计了一个抽象的模板&#xff0c;算法的具体代码细节由子类来实现&#xff0c;从…