找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 1971|回复: 2

一个关于”+“重载的问题

[复制链接]
发表于 2009-11-3 04:22:43 | 显示全部楼层 |阅读模式 IP:江苏扬州
小弟在自定义的String类时,重载了一个"+"。但出现了编译问题,请各位大哥指教一下。其程序如下:
#include<iostream>
using namespace std;
class String
{
public:
String();//ok
String(char *p) ;//ok
String(String &strs);//ok
~String();//ok

//===============成员函数===================
int length() const;//ok
int find(String &str);//ok

//===============运算符重载=====================
void operator =(String str);//ok
friend bool operator ==(String str1,String str2);//ok
friend bool operator <(String str1,String str2);//ok
friend bool operator >(String str1,String str2);//ok
friend String operator + (String str1,String str2);

//================流操作符重载===================
friend istream operator >>(istream &cin,String &str);//ok
friend ostream operator <<(ostream &cout,String &str);//ok
char operator [](int n) const;//ok

private:
char *strp=new char[256];
};

//不带参数的构造函数的实现
String::String()
{
strp[0]=NULL;
}
//带参数的构造函数的实现
String::String(char *p)
{
for(int i=0;p[i]!=NULL;i++)
strp[i]=p[i];
strp[i]=NULL;
}
//深拷贝构造函数的实现
String::String(String &strs)
{
for(int i=0;strs.strp[i]!=NULL;i++)
strp[i]=strs.strp[i];
strp[i]=NULL;
}
//析构函数的实现
String::~String()
{
if(strp)delete [] strp;
}
//========================成员函数的实现=========================
int String::length() const
{
return strlen(strp);
}
//======================运算符重载的实现===============================
void String::operator = (String str)
{
if(strp) delete [] strp;
for(int i=0;str.strp[i]!=NULL;i++)
strp[i]=str.strp[i];
strp[i]=NULL;
}
String operator +(String str1,String str2)
{
int l1 = strlen(str1.strp),l2 = strlen(str2.strp);
char *str0=new char(l1+l2+1);
for(int i=0;i<l1;i++)
str0[i]=str1.strp[i];
for(int j=l1;j<(l1+l2);j++)
str0[j]=str2.strp[j-l1];
str0[l1+l2]=NULL;
return String(str0);
}
char String::operator [](int n) const
{
return *(strp+n);
}

//===================== 比较运算符重载的实现=======================
bool operator ==(String str1,String str2)
{
if(str1.length()!=str2.length())
return false;
else
{
for(int i=0;i<str1.length();i++)
{
if(str1.strp[i]!=str2.strp[i])
return false;
}
return true;
}
}
bool operator <(String str1,String str2)
{
if(str1==str2)
return false;
else
{
for(int i=0;str1.strp[i]!=str2.strp[i];i++){}
return (str1.strp[i]<str2.strp[i]);
}
}

bool operator >(String str1,String str2)
{
if(str1==str2)
return false;
else
{
for(int i=0;str1.strp[i]!=str2.strp[i];i++){}
return (str1.strp[i]>str2.strp[i]);
}
}
//=====================流操作符重载的实现=====================
istream operator >>(istream &cin,String &str)
{
cin>>str.strp;
return cin;
}
ostream operator <<(ostream &cout,String &str)
{
cout<<str.strp;
return cout;
}

//====================find函数重载的实现=======================
int String::find(String &str)
{
int len=length();
if(len<str.length())
return -1;
else
{
int i,j,k=0;
f: for(i=k;strp[i]!=str[0]&&i<len;i++){}
if(len-i<str.length())
return -1;
else
{
for(j=0;j<str.length();j++)
{
if(strp[i+j]!=str[j])
break;
}
if(j==str.length())
return i;
else
{
k=i+1;
goto f;
}
}
}
}
//====================main=============================
int main()
{
String s1,s2,s3;
cin>>s1>>s2;
s3=s1+s2;
cout<<s3<<endl;
for(int i=0;i<s3.length();i++)
cout<<s3[i];
cout<<endl;
if(s1>s2)
cout<<s1<<" is more larger than "<<s2<<endl;
cout<<s3.find(s2)<<endl;
return 0;
}
发表于 2009-11-3 04:22:44 | 显示全部楼层 IP:江苏扬州
这么长。你最好说说问题所在。。哪里编译有错。。才好对症下药。。。
回复

使用道具 举报

发表于 2009-11-3 04:22:45 | 显示全部楼层 IP:江苏扬州
int l1 = strlen(str1.strp),l2 = strlen(str2.strp);
char *str0=new char(l1+l2+1);
---------------
char *str0=new char[l1+l2+1)]
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-30 17:32 , Processed in 0.276838 second(s), 13 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表