body, table{font-family: 微软雅黑; font-size: 10pt}
table{border-collapse: collapse; border: solid gray; border-width: 2px 0 2px 0;}
th{border: 1px solid gray; padding: 4px; background-color: #DDD;}
td{border: 1px solid gray; padding: 4px;}
tr:nth-child(2n){background-color: #f8f8f8;}

#include <iostream>
#include<stdlib.h>
#include<stdio.h>
#include<sstream>
#include<string.h>
using namespace std;
class String
{
        private:
                char *pstr_;
        public:
                String();
                String(const char *);
                String(const String&);
                ~String();
                String & operator = (const String &);
                String & operator = (const char *);
                String & operator += (const String &);
                String & operator += (const char *);
                char & operator [] (std::size_t index);
                const char & operator [](std::size_t index)const;
                std::size_t size() const;
                const char* c_str() const;
                friend bool operator == (const String &,const String &);
                friend bool operator != (const String &,const String &);
                friend bool operator < (const String &,const String &);
                friend bool operator > (const String &,const String &);
                friend bool operator <= (const String &,const String &);
                friend bool operator >= (const String &,const String &);
                friend std::ostream & operator << (std::ostream & os,const String &s);
                friend std::istream & operator >> (std::istream & is,String & s);
};
String operator + (const String &,const String &);
String operator + (const String &,const char *);
String operator + (const char *,const String &);

String::String()
{
        cout<<"String()"<<endl;
        pstr_=new char[1];
        strcpy(pstr_,"");
}
String::~String()
{
        cout<<"~String()"<<endl;
        delete []pstr_;
}
String::String(const char *str)
{
        cout<<"String(const char *)"<<endl;
        pstr_=new char[strlen(str)+1];
        strcpy(pstr_,str);
}
String :: String(const String & s)
{
        cout<<"String(const String &)"<<endl;
        pstr_=new char[strlen(s.pstr_)+1];
        strcpy(pstr_,s.pstr_);
}
String & String::operator = (const String & s)
{
        cout<<"String & operator =(const String &)"<<endl;
        this->~String();
        pstr_=new char[strlen(s.pstr_)+1];
        strcpy(pstr_,s.pstr_);
        return *this;
}
String & String::operator =(const char *s)
{
        cout<<"String & operator=(const char *)"<<endl;
        this->~String();
        pstr_=new char[strlen(s)+1];
        strcpy(pstr_,s);
        return *this;
}
String & String::operator +=(const String &s)
{
        cout<<"String & operator += (const String &)"<<endl;
        int len1=strlen(this->pstr_);
        int len2=strlen(s.pstr_);
        char *a=(char*)calloc(len1,sizeof(char));
        strcpy(a,this->pstr_);
        this->~String();
        this->pstr_=new char[len1+len2+1];
        sprintf(this->pstr_,"%s%s",a,s.pstr_);
        return *this;
}
String & String::operator += (const char *s)
{
        cout<<"String & operator += (const char *)"<<endl;
        int len1=strlen(this->pstr_);
        int len2=strlen(s);
        char *a=(char*)calloc(len1,sizeof(char));
        strcpy(a,this->pstr_);
        this->~String();
        this->pstr_=new char[len1+len2+1];
        sprintf(this->pstr_,"%s%s",a,s);
        return *this;
}
std::ostream &  operator<<(std::ostream & os,const String &s)
{
        cout<<"std::ostream & operator << (std::ostream & ,const String &)"<<endl;
        os<<s.pstr_;
        return os;
}
char& String::operator[] (std::size_t index)
{
        cout<<"char & operator[] (std:: size_t index)"<<endl;
        int len=strlen(this->pstr_);
        char *a=(char*)calloc(len,sizeof(char));
        strcpy(a,pstr_);
        return a[index];
}

const char& String::operator[](std::size_t index)const
{
        cout<<"const char & operator[] (std:: size_t index)const"<<endl;
        int len=strlen(this->pstr_+1);      //这里错了,this->pstr_+1相当于指正偏移到下一个字符
        char *a=(char*)calloc(len,sizeof(char));
        strcpy(a,pstr_);
        return a[index];
}
std::size_t String::size()const
{
        cout<<"std::size_t size()const"<<endl;
        int len=strlen(this->pstr_);
    return len;
}
const char* String::c_str() const
{
        cout<<"const char* c_str() const"<<endl;
        int len=strlen(this->pstr_+1);
        char *a=(char*)calloc(len,sizeof(char));  
//这里不管申请多大的空间,后面拷贝函数如果不够他都会自动在申请空间所以结果没出现错误
        strcpy(a,pstr_);
        return a;
}
bool operator == (const String & a1,const String &a2)
{
        cout<<"bool operator == (const String &,const String &)"<<endl;
        if((strcmp(a1.c_str(),a2.c_str()))==0)
                        return 1;
        return 0;
}
bool operator != (const String & a1,const String & a2)
{
        cout<<"bool operator != (const String &,const String &)"<<endl;
        if((strcmp(a1.c_str(),a2.c_str()))!=0)
                        return 1;
        return 0;
}
bool operator < (const String &a1,const String &a2)
{
        cout<<"bool operator < (const String &,const String &)"<<endl;
        if((strcmp(a1.c_str(),a2.c_str()))<0)
                        return 1;
        return 0;
}
bool operator > (const String &a1,const String &a2)
{
        cout<<"bool operator > (const String &,const String &)"<<endl;
        if((strcmp(a1.c_str(),a2.c_str()))>0)
                        return 1;
        return 0;
}
bool operator <= (const String &a1,const String &a2)
{
        cout<<"bool operator <= (const String &,const String &)"<<endl;
        if((strcmp(a1.c_str(),a2.c_str()))<0)
                        return 1;
        else if((strcmp(a1.c_str(),a2.c_str()))==0)
                        return 1;
        return 0;
}
bool operator >= (const String &a1,const String &a2)
{
        cout<<"bool operator >= (const String &,const String &)"<<endl;
        if((strcmp(a1.c_str(),a2.c_str()))>0)
                        return 1;
        else if((strcmp(a1.c_str(),a2.c_str()))==0)
                        return 1;
        return 0;
}
std::istream & operator >> (std::istream & is,String &s)
{
        cout<<"std::istream & operator >> (std::istream &m,String &)"<<endl;
        is>>s.pstr_;
        return is;
}
String operator + (const String &a1,const String &a2)
{
        cout<<"String operator + (const String &,const String &)"<<endl;
        String tmp=a1;
        tmp+=a2;
        return tmp;
}
String operator + (const String &a1,const char * a2)
{
        cout<<"String operator + (const String &,const char *)"<<endl;
        String tmp=a1;
        tmp+=a2;
        return tmp;
}
String operator + (const char *a1,const String & a2)
{
        cout<<"String operator + (const char *,const String &)"<<endl;
        String tmp;
        tmp+=a1;
        tmp+=a2;
        return tmp;
}


//测试代码
int main()
{
        String s;
        String s1("hello");
        String s2(s1);
        String s3="world";
        s1=s2;
        String s4;
        s4="wangdao";
        s+=s3;
        s4+="nihao";
        cout<<s4<<endl;
        cout<<s4[2]<<endl;
        cout<<s4.size()<<endl;
        cout<<s4.c_str()<<endl;
        bool bool1=(s1>s4);
        cout<<bool1<<endl;
        bool bool2=(s1>=s3);
        cout<<bool2<<endl;
        cin>>s;
        cout<<s<<endl;
        String s5=s1+s2;
        cout<<s5<<endl;
        String s6=s1+"shenzhen";
        cout<<s6<<endl;
        String s7="shenzhen1"+s1;
        cout<<s7<<endl;
        return 0;
}

String类运算符重载,自己实现的更多相关文章

  1. c++类运算符重载遇到的函数形参问题

    class A { public: A(int arg1, int arg2); ~A(); A &operator = ( A &other); A operator + ( A & ...

  2. 从零开始学C++之运算符重载(三):完善String类([]、 +、 += 运算符重载)、>>和<<运算符重载

    在前面文章中使用过几次String类的例子,现在多重载几个运算符,更加完善一下,并且重载流类运算符. []运算符重载 +运算符重载 +=运算符重载 <<运算符重载 >>运算符重 ...

  3. 完善String类([]、 +、 += 运算符重载)、>>和<<运算符重载

    在前面文章中使用过几次String类的例子,现在多重载几个运算符,更加完善一下,并且重载流类运算符. []运算符重载 +运算符重载 +=运算符重载 <<运算符重载 >>运算符重 ...

  4. 04737_C++程序设计_第9章_运算符重载及流类库

    例9.1 完整实现str类的例子. #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> ...

  5. 【C++札记】实现C++的string类

    C++有了string类使得操作字符串变得很方便.有关string类,面试过程中也经常问到的就是自己实现一个sring类.下边实现个String类供大家参考: String.h #pragma onc ...

  6. 深入C++05:运算符重载

    运算符重载 1.复数类 运算符重载目的:使对象运算表现得和编译器内置类型一样: 复数类例子 #include<iostream> using namespace std; class CC ...

  7. C++:String类

    String类 1.使用String类必须在程序的开始包括头文件string,即要有如下语句:#include<string> 2.string类字符串对象的使用方法与其他对象一样stri ...

  8. C++中的运算符重载练习题

    1.RMB类 要求: 定义一个RMB类 Money,包含元.角.分三个数据成员,友元函数重载运算符‘+’(加)   和 ‘-’(减),实现货币的加减运算     例如:    请输入元.角 分:    ...

  9. 包装类、基本数据类型及String类之间的相互转换

    包装类:8种基本数据类型对应一个类,此类即为包装类 一.基本数据类型 包装类 及String之间的转换 1.基本数据类型转化为包装类:调用包装类的构造器      int i=10;     Inte ...

随机推荐

  1. 如何高效的遍历HashMap 以及对key 进行排序

    Map<Integer ,Object> map = new HashMap<Integer,Object>(); for(int i = 0; i<=100;i++){ ...

  2. Python日期字符串比较

    作者:Syn良子 出处:http://www.cnblogs.com/cssdongl 转载请注明出处 需要用python的脚本来快速检测一个文件内的二个时间日期字符串的大小,其实实现很简单,首先一些 ...

  3. 资产证券化(ABS)+ 特殊目的信托(SPV)

    资产证券化是指以基础资产未来所产生的现金流为偿付支持,通过结构化设计进行信用增级,在此基础上发行资产支持证券(Asset-backed Securities, ABS)的过程,通过将有形或者无形资产作 ...

  4. poj 2187:Beauty Contest(旋转卡壳)

    Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 32708   Accepted: 10156 Description Bes ...

  5. Python学习笔记(十二)—Python3中pip包管理工具的安装【转】

    本文转载自:https://blog.csdn.net/sinat_14849739/article/details/79101529 版权声明:本文为博主原创文章,未经博主允许不得转载. https ...

  6. [转载]Javassist 使用指南(一)

    ======================= 本文转载自简书,感谢原作者!. 原链接如下:https://www.jianshu.com/p/43424242846b =============== ...

  7. java 普通内部类和静态内部类

    区别1: 普通内部类实例化后的对象持有外部类的引用,在非静态类内部可以访问外部类的成员:静态内部类实例化不持有外部对象引用,不能访问外面的方法和成员: 从耦合度上来讲,普通内部类跟外部类耦合程度很高, ...

  8. SQL映射文件-----MySQL关系映射【1对1,1对多,多对多】

    SSM框架下,mapper.xml 中 association 标签和 collection 标签的使用 当数据库中表与表之间有关联时,在对数据库进行操作时,就不只是针对某一张表了,需要联表查询 My ...

  9. 【pytorch】pytorch基础学习

    目录 1. 前言 # 2. Deep Learning with PyTorch: A 60 Minute Blitz 2.1 base operations 2.2 train a classifi ...

  10. 分析ReentrantLock的实现原理

    http://www.jianshu.com/p/fe027772e156 什么是AQS AQS即是AbstractQueuedSynchronizer,一个用来构建锁和同步工具的框架,包括常用的Re ...