9.23每日作业

devtools/2024/9/24 14:17:31/

仿照string类,自己手动实现 My_string

list.h

#ifndef LIST_H
#define LIST_H
#include <iostream>using namespace std;class My_string
{
private:char *ptr;int size;int len;public://无参构造My_string();//有参构造My_string(const char * src);My_string(int num, char value);//拷贝构造My_string(const My_string& other);//拷贝赋值My_string & operator= (const My_string &other);//析构构造~My_string();//判空bool MYempty() const;//尾插void push_back(char value);//尾删void pop_back();//at函数实现char &at(int index);//清空函数void clear();//返回C风格字符串char *data();//返回实际长度int get_length();//返回当前最大容量int get_size();//君子函数:二倍扩容void resize();void show();
};
#endif // LIST_H

list.c

#include "list.h"
using namespace std;
My_string::My_string():size(15)
{this->ptr = new char[15];this->ptr[0] = '\0';this->len = 0;
}
//有参构造
My_string::My_string(const char * src)
{this->len = 0;for(int i=0;src[i] != 0;i++){this->len++;}this->size = this->len+1;this->ptr = new char[this->size];for(int i = 0;src[i] != 0;i++){this->ptr[i] = src[i];}
}
My_string::My_string(int num, char value)
{this->len = num;this->size = this->len+1;this->ptr = new char[this->size];for (int i = 0; i < this->len; i++){this->ptr[i] = value; // 用value填充数组}this->ptr[this->len] = '\0'; // 添加结束符
}
//拷贝构造
My_string::My_string(const My_string& other):ptr(new char[other.len + 1]),size(other.size), len(other.len)
{for(int i = 0;other.ptr[i] != 0;i++) // 复制字符串内容{this->ptr[i] = other.ptr[i];}
}
//拷贝赋值
My_string & My_string::operator= (const My_string &other)
{if(this != &other)               //防止自己给自己赋值{this->size = other.size;this->len = other.len;//this->ptr = other.ptr;                 //浅拷贝for(int i = 0;other.ptr[i] != 0;i++)     //深拷贝{this->ptr[i] = other.ptr[i];}}return *this;                  //返回值自身的引用
}
//析构构造
My_string::~My_string()
{delete[] ptr;     //需要显性定义析构函数,在析构函数的函数体内释放堆区空间cout<<"Person::析构函数,this = "<<this<<endl;
}
//判空
bool My_string::MYempty() const
{return this->ptr == nullptr || this->len == 0; // 如果指针为空或长度为0,则认为是空
}
//尾插
void My_string::push_back(char value)
{this->size++;this->ptr[len] = value;this->len++;this->ptr[size] = 0;
}
//尾删
void My_string::pop_back()
{this->ptr[len-1] = 0;this->size--;this->len--;
}
//at函数实现
char & My_string::at(int index)
{static char num;num = this->ptr[index-1];return num;  
}
//清空函数
void My_string::clear()
{this->size = 15;delete[] ptr;this->ptr = new char[1];this->ptr[0] = '\0';this->len = 0;
}
//返回C风格字符串
char *My_string::data()
{return ptr;
}
//返回实际长度
int My_string::get_length()
{return this->len;
}
//返回当前最大容量
int My_string::get_size()
{return this->size;
}
//君子函数:二倍扩容
void My_string::resize()
{size *= 2; // 容量翻倍char* newptr = new char[size]; // 分配新的内存for(int i = 0;this->ptr[i] != 0;i++)     //深拷贝{newptr[i] = this->ptr[i];}delete[] ptr; // 释放旧内存this->ptr = newptr; // 更新指针
}
void My_string::show()
{cout<< "ptr = " << this->ptr << endl;cout<< "size = " << this->size << endl;cout<< "len = " << this->len << endl;
}

main.c

#include "list.h"using namespace std;int main()
{My_string s;s.show();if(s.MYempty()==1){cout << "s" << "为空" << endl;}My_string s1("hello world");s1.show();My_string s2(5,'A');s2.show();My_string s3(s1);s3.show();s.operator=(s2);s.show();My_string s4 = s1;s4.push_back('B');s4.show();s4.pop_back();s4.show();cout << s4.at(3) << endl;s4.clear();if(s4.MYempty()==1){cout << "s4" << "为空" << endl;}s3.data();s3.show();cout << s2.get_length() << endl;cout << s2.get_size() << endl;s1.resize();s1.show();return 0;
}


http://www.ppmy.cn/devtools/116539.html

相关文章

EfficientFormer实战:使用EfficientFormerV2实现图像分类任务(一)

摘要 EfficientFormerV2是一种通过重新思考ViT设计选择和引入细粒度联合搜索策略而开发出的新型移动视觉骨干网络。它结合了卷积和变换器的优势&#xff0c;通过一系列高效的设计改进和搜索方法&#xff0c;实现了在移动设备上既轻又快且保持高性能的目标。这一成果为在资源受…

5.MySQL表的约束

目录 表的约束空属性&#xff08;非空约束&#xff09;默认值&#xff08;default约束&#xff09;列描述&#xff08;comment&#xff09;zerofill主键&#xff08;primary key约束&#xff09;自增长&#xff08;auto_increment&#xff09;唯一键&#xff08;unique约束&…

Java项目实战II基于Java+Spring Boot+MySQL的读书笔记共享平台(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、论文参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 在信息爆炸…

Idea 开发工具安装

在进入正式的编程学习之前&#xff0c;还是需要先安装一个好用的编程工具的。 个人推荐两款&#xff1a;JetBrains IntelliJ IDEA 和 Visual Studio Code (VS Code) 。 我这边使用的是 JetBrains IntelliJ IDEA 2023.3 版本的&#xff0c;因为后续会同时涉及到前端代码和后端…

双向链表

目录 区别 创建结构体 初始化 判断链表结束 区别 无头单向非循环链表&#xff1a; 结构简单&#xff0c;一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构&#xff0c;如哈希桶、图的邻接表等等。另外这种结构在笔试面试中出现很多 带头双向循环链表&#xf…

【机器学习(九)】分类和回归任务-多层感知机 (MLP) -Sentosa_DSML社区版

文章目录 一、算法概念二、算法原理&#xff08;一&#xff09;感知机&#xff08;二&#xff09;多层感知机1、隐藏层2、激活函数sigma函数tanh函数ReLU函数 3、反向传播算法 三、算法优缺点&#xff08;一&#xff09;优点&#xff08;二&#xff09;缺点 四、MLP分类任务实现…

简单接口自动化框架实现(Python+requests+pytest)

1、接口自动化流程 1.需求分析2.挑选需要做自动化测试的功能3.设计测试用例4.搭建自动化测试环境[可选]5.设计自动化测试项目的架构[可选]6.编写代码7.执行测试用例8.生成测试报告并分析结果 2、框架结构 --api -->封装请求 --scripts -->编写测试脚本…

jmeter本身常用性能优化方法

第一种设置&#xff1a; 修改Jmeter.bat文件&#xff0c;调整JVM参数(修改jmeter本身的最小最大堆内存)&#xff0c;默认都是1个G set HEAP-Xms5g -Xmx5g -XX:MaxMetaspaceSize256m我的本机内存是8G&#xff0c;那最大可以设置870%(本机内存的70%)5.6g 这里我设置的5g 如果…