寫一個能處理字符串的類,其數據成員如下所示:
class String
{
public:
...//需要的成員函數(若需要的話,聲明友元函數)
private:
char *p; //指向存儲的字符串
int len; //記錄字符串的長度
;
class String
{
public:
...//需要的成員函數(若需要的話,聲明友元函數)
private:
char *p; //指向存儲的字符串
int len; //記錄字符串的長度
};
請構造String類的加、減運算。其中,s1 + s2將兩個字符串的連接起來;s1 - s2是將s1的尾部空格和s2的前導空格去除後的連接。提示:有指針成員,設計時要注意。這個,你懂的。
/*
* Copyright (c) 2015,煙臺大學計算機學院
* All right reserved.
* 作者:曹莉萍
* 文件:Demo.cpp
* 完成時間:2015年05月16日
* 版本號:v1.0
*/
#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;
}
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]; //原誤寫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);
i=0;
while(i<s2.len&&c2[i]==' ') ++i;
int j=0;
while(i<s2.len&&c2[i]!='\0')
{
c2[j]=c2[i];
++i;
++j;
}
c2[j]='\0';
//將這兩部分接起來
s.len = strlen(c1)+strlen(c2);
s.p = new char[s.len+1]; //原誤寫char(s.len+1)
strcpy(s.p,c1);
strcat(s.p,c2);
delete c1;
delete 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;
}