第八周项目4扩充string类

/*01.
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称:
* 作    者: 
* 完成日期: 2014 年 04月 17 日
* 版本号: v1.0
* 问题描述:
*在P324基础上,在String类中增加一个
数据成员len表示字符串中字符个数,
然后构造String类的相关运算。这些运算可以包括:
s1 + s2用于两个字符串的连接;
s1 - s2用于将s1的尾部空格和s2的前导空格去除后的连接;
*/
#include <iostream>
#include <Cstring>
using namespace std;
class String
{
public:
    String( );                         //默认构造函数
    String(const char *s);
    String(String &str);               //构造函数
    ~String();
    void display( );
    friend String operator + (String &s1,String &s2 );
    friend String operator - (String &s1,String &s2 );
private:
    char *p;
    int len;                                       //字符型指针,用于指向字符串
};
String::String()
{
    len=0;
    p = NULL;
}
String::String(const char *s)
{
    len = strlen(s);
    p = new char[len+1];
    strcpy(p,s);
}

String::String(String &str)
{
    len = str.len;
    if(p!=NULL) delete []p;   //当发生在赋值等情形时,原对象可能已经存在,需释放原有空间
    p = new char[len+1];
    strcpy(p,str.p);
}

String::~String()
{
    if(!p) delete []p;//if(p==NULL),如果p是无效的释放p!
}

void String::display( )     //输出p所指向的字符串
{
    cout<<p<<endl;
}

String operator+(String &s1, String &s2 )
{
    String s;
    s.len =s1.len+s2.len;
    s.p=new char[s.len+1];
    strcpy(s.p,s1.p);
    strcat(s.p,s2.p);
    return s;
}
String operator-(String &s1, String &s2 )
{
    String s;
    //c1为截去尾部空格的字符串
    char *c1=new char[s1.len+1];
    strcpy(c1,s1.p);
    int i=s1.len-1;
    while(i>=0&&c1[i]==' ') --i;
    c1[i+1]='\0';
    //c2为去除前导空格的字符串
    char *c2=new char[s2.len+1];
    strcpy(c2,s2.p);
    int j=0,k=1;
    while(k<s2.len+1&&c2[k]!='\0')
    {
        c2[j]=c2[k];
        ++k;
        ++j;
    }
    c2[j]='\0';

    //将这两部分接起来
    s.len=strlen(c1)+strlen(c2);
    s.p=new char[s.len+1];
    strcpy(s.p,c1);
    strcat(s.p,c2);//连接!!!
    return s;
}

int main( )
{
    String string1(" Hello  "), string2(" World ");
    string1.display();
    string2.display();
    String string3;
    string3=string1+string2;
    string3.display();
    string3=string1-string2;
    string3.display();
    return 0;
}

心得:new  char[   ]
!!!!

if(!p) 如果p是无效的!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值