c++ 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);
//注:如果是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<<str3<<"/n"<<str3.size()<<endl;
return 0;
}


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值