C++中string类实现教程
string类的实现
#include
#include
#include
using namespace std;
class String{
friend ostream& operator<< (ostream&,String&);//重载<<运算符
friend istream& operator>> (istream&,String&);//重载>>运算符
public:
String(const char* str=NULL); //赋值构造兼默认构造函数(char)
String(const String &other); //赋值构造函数(String)
String& operator=(const String& other); //operator=
//String operator+(const String &other)const; //operator+ 成员函数的版本
bool operator==(const String&); //operator==
char& operator[](unsigned int); //operator[]
size_t size(){return strlen(m_data);};
friend const String operator + (const String &other1, const String &other2);
//注:如果是friend const String operator + (const String &other1, const String &other2) const,则表示为const函数,编译不过,提示:‘cannot have cv-qualifier’,
//即:不能有CV限定,在C++中CV指const和volatile—1、非成员函数不能有CV限定,2、静态成员函数不能有CV限定
//因为const函数,表明该函数有const this指针,而友元函数并不是成员函数,所以冲突。另外注意:friend const String operator + (),表示的是返回值为const,而不是const函数。
~String(void) {delete[] m_data;}
private:
char *m_data; // 用于保存字符串
};
inline String::String(const char* str)
{
if(!str)m_data=0; //声明为inline函数,则该函数在程序中被执行时是语句直接替换,而不是被调用
else {
m_data=new char[strlen(str)+1];
strcpy(m_data,str);
}
}
inline String::String(const String &other)
{
if(!other.m_data)m_data=0;//在类的成员/友元函数内可以访问同种对象的私有成员(同种类则是友元关系)
else
{
m_data=new char[strlen(other.m_data)+1];
strcpy(m_data,other.m_data);
}
}
inline String& String::operator=(const String& other)
{
if (this!=&other)
{
delete[] m_data;
if(!other.m_data) m_data=0;
else
{
m_data = new char[strlen(other.m_data)+1];
strcpy(m_data,other.m_data);
}
}
return *this;
}
/****成员函数的版本
inline const String String::operator+(const String &other)const
{
String newString;
if(!other.m_data)
newString = *this;
else if(!m_data)
newString = other;
else
{
newString.m_data = new char[strlen(m_data)+strlen(other.m_data)+1];
strcpy(newString.m_data,m_data);
strcat(newString.m_data,other.m_data);
}
return newString;
}
****/
//友元函数的版本如下:
const String operator + (const String &other1, const String &other2) /* 是:operator + ,而不是:String::operator + ,因为友元函数不是成员函数 */
{
String newString;
if ((!other1.m_data) && (!other2.m_data))
newString.m_data = NULL;
else if ((!other1.m_data) && (other2.m_data != 0))
newString = other2;
else if ((other1.m_data != 0) && (other2.m_data == 0))
newString = other1;
else
{
newString.m_data = new char[strlen(other1.m_data)+strlen(other2.m_data)+1];
strcpy(newString.m_data,other1.m_data);
strcat(newString.m_data,other2.m_data);
}
return newString;
}
inline bool String::operator==(const String &s)
{
if ( strlen(s.m_data) != strlen(m_data) )
return false;
return strcmp(m_data,s.m_data)?false:true;
}
inline char& String::operator[](unsigned int e)
{
if (e>=0&&e<=strlen(m_data))
return m_data[e];
}
ostream& operator<<(ostream& os,String& str)
{
os << str.m_data;
return os;
}
istream &operator>>( istream &input, String &s )
{
char temp[ 255 ]; //用于存储输入流
input>>setw(255)>>temp;
s = temp; //使用赋值运算符
return input; //使用return可以支持连续使用>>运算符
}
int main()
{
String str1="Aha!";
String str2="My friend";
String str3 = str1+str2;
str1+str2 = str3;
cout<
上一篇: Linux 学习
下一篇: 安装zabbix4.0+grafana