当前位置: 首页 > article >正文

C++(9.23)

主函数

#include"head.h"
int main()
{
    My_string s2("hello");
    My_string s3(5,'A');
    s2.show();
    s3.show();
    My_string s1=s2;
    s1.show();
    My_string s4;
    s4=s3;
    s4.show();
    if(s4.empty_if())
    {
        cout<<"该字符数组为空"<<endl;
    }
    else
    {
        cout<<"该字符数组不为空"<<endl;
    }
     s1.push_back('!');
     s1.show();

     s1.pop_back();
     s1.show();
     cout << "第一个位置是 : " << s1.at(1) << endl;
     s1.clear();
     s1.show();
     cout << "s2当前的长度是 : " << s2.get_length()<<"s3当前的最大容量是"<<s3.get_size()<<endl;

    return 0;
}

头文件:

#ifndef HEAD_H
#define HEAD_H
#include <iostream>
#include <cstring>
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);
             void show();
             bool empty_if();
             void push_back(char value);
             void pop_back();
             char &at(int index);
             void clear();
            int get_length();
             int get_size();
             ~My_string();
};
#endif // HEAD_H

源文件:

#include"head.h"
using namespace std;

My_string::My_string():size(15)
{
    this->ptr =new char[size];
    this->ptr [0]='\0';
    this->len=0;
}
My_string::My_string(const char *src)
{
    this->len=strlen(src);
    this->size=this->len+1;
    this->ptr =new char[size];
    strcpy(this->ptr,src);
}
My_string::My_string(int num,char value)
{
    this->len=num;
    this->size=this->len+1;
    this->ptr =new char[num];
    for(int i=0;i<5;i++)
    {
    this->ptr[i]=value;
    }
}
My_string::My_string(const My_string &other)
{
    this->len = other.len;
    this->size = other.size;
    this->ptr = new char[size];  // 分配新的内存
    strcpy(this->ptr, other.ptr);  // 复制源对象的字符串内容
}
My_string&My_string ::operator=(const My_string &other)
{
    if(this != &other)               //防止自己给自己赋值
           {
               this->size = other.size;
               this->len = other.len;
               this->ptr = new char[size];
               strcpy(this->ptr ,other.ptr);              //深拷贝
           }
           return *this;                  //返回值自身的引用
}
void My_string::show()
{
    cout<<this->ptr<<endl;
}
My_string::~My_string()
{
    delete this->ptr;
}

bool My_string::empty_if()
{
    return this->len==0;
}
void My_string::push_back(char value)
   {

       ptr[len] = value;           // 在尾部添加字符
       ptr[len+1] = '\0';  // 确保字符串以空字符结尾
       this->len++;
   }
   void My_string::pop_back()
   {
       if (this->len > 0)                  // 确保字符串非空
       {

           ptr[len-1] = '\0'; // 更新终止符
           this->len--;
       }
   }
   char &My_string::at(int index)
      {
          return ptr[index-1];             // 返回引用以支持修改
      }
   void My_string::clear()
     {
         this->len = 0;                       // 重置长度为 0
         ptr[0] = '\0';                 // 以空字符结束
     }
   int My_string::get_length()
      {
          return this->len;
      }
   int My_string::get_size()
       {
           return this->size;
       }

 

 

 


http://www.kler.cn/a/319746.html

相关文章:

  • UI自动化测试:异常截图和page_source
  • 海云安开发者安全智能助手D10荣膺 “ AI标杆产品 ” 称号,首席科学家齐大伟博士入选2024年度 “ 十大杰出青年 ”
  • 诡异的Spring @RequestBody驼峰命名字段映射失败为null问题记录
  • FPGA车牌识别
  • 计算机网络-物理层
  • 【服务治理中间件】consul介绍和基本原理
  • Profinet通讯电能计量装置 功能介绍
  • 智慧体育馆可视化:实时监控与智能管理
  • 滑动窗口算法第一弹(长度最小的子数组,无重复字符的最长子串 最大连续1的个数III)
  • C++: 继承
  • grafana 使用常见问题
  • Unity数据持久化4——2进制
  • Flink的反压机制:底层原理、产生原因、排查思路与解决方案
  • MySQL高阶1949-坚定地友谊
  • 查询最近正在执行的sql(DM8 : 达梦数据库)
  • 【艾思科蓝】Spring Boot实战:零基础打造你的Web应用新纪元
  • 漫谈 Kubernetes 的本质
  • 网络安全:腾讯云智、绿盟、美团、联想的面经
  • [WMCTF2020]Make PHP Great Again 2.01
  • 使用 Python 绘制 BTC 期权的波动率曲面
  • ③无需编程 独立通道 Modbus主站EtherNet/IP转ModbusRTU/ASCII工业EIP网关串口服务器
  • 单词搜索问题(涉及递归等)
  • docker多阶段镜像制作,比如nginx镜像,编译+制作
  • 【SpringBoot整合Redis测试Redis集群案例】
  • 【QT 5 调试软件+Linux下调用脚本shell-无法调度+目录拼写+无法找目录+sudo权限(2)+问题解决方式+后续补充】
  • linux网络编程8