c++ string类的实现

来源:互联网 发布:局域网文件传输软件 编辑:程序博客网 时间:2024/05/16 05:31

友元函数可以转换左右操作数的顺序,而成员函数必须保证左操作数string已经处于正确的形式。

#include<iostream>#include<iomanip>#include<string.h>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); //<span style="font-family: Arial, Helvetica, sans-serif;">operator+()  友元函数的版本</span>    /***  注:如果是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;}int main(){    String str1="Aha!";    String str2="My friend";    String str3 = str1+str2;    //str1+str2 = str3; //因为是:<span style="font-family: Arial, Helvetica, sans-serif;">const String operator +(),所以禁止写出这样的代码:</span><span style="font-family: Arial, Helvetica, sans-serif;">str1+str2 = str3</span>    cout<<str3<<"/n"<<str3.size()<<endl;return 0;}


0 0
原创粉丝点击