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
- [C++]String类的实现
- [C++]String类的实现
- [C++]String类的实现
- C++String类的实现
- 【c++】string类的实现
- C++string类的实现
- C++string类的实现
- C++String类的实现
- C++string类的实现
- C/C++string类的实现
- C++string类的一个实现
- C++string类的简单实现
- c++string类的简单实现
- C++—String类接口的实现
- 【C/C++】String类实现
- C string buffer的实现
- C++:模拟实现string类
- 模拟实现string类(c++)
- c++ string类的内部实现
- uboot配置和启动过程1(主Makefile分析)
- 构造(Recover the String,cf 709D)
- 坚持#第20天~车子归还努力学Java
- wifidog原理分析
- c++ string类的实现
- uboot配置和启动过程2(mkconfig分析)
- React Native 每日一学(Learn a little every day)
- python3.x 中urllib的使用
- mysql-语句
- 【例题】【网络流(费用流)】NKOJ 3738 学号
- 6种常见排序算法(java版)
- [vijos 1204]CoVH之柯南开锁
- 软件设计六大原则