重写string类

mystring类实现的都是些常用的操作,字符串的累加,各种形式的赋值,迭代器的自增,自减等!通过写这个感觉主要熟悉了c++运算符重载的原理,另外就是熟悉了string对象的内置常用方法。


头文件

//mystring.h
#pragma once
#include
#include
#include
#include
using namespace std;

class mystring
{
    friend ostream&operator<<(ostream&out,const mystring&s);
    friend istream&operator>>(istream&in,mystring&s);

private:
    char *p;

public:
    int len;
    class iterator ;
    mystring();
    mystring(const char *s);
    mystring(mystring const&s);
    ~mystring();

public :
    char operator[](const int i);
    mystring& operator=(const mystring&s);
    mystring& operator=(const char * s);
    bool operator==(mystring const&s);
    bool operator==(const char *s);
    mystring& operator+=(const char*s) ;
    mystring& operator+=(mystring const s) ;
    bool operator!=(const char *s);
    bool operator!=(const mystring&s);
    bool operator<(const mystring&s);
    bool operator<(const char *s);
    bool operator>(const mystring &s);

public :
    char* c_str() ;
    int length();
    bool operator>(const char *s);
    int indexof(const char& s);
    int lastIndexOf(const char &s);
    char* substr(int start, int  end);
    char* substr(int start) ;
    char* data();

public :
    iterator  end()const 
    {
        if(this->len == 0)
        {
            throw exception() ;
        }

        int len = strlen(this->p) ;
        return iterator(this, len) ;
    }

    iterator begin()const
    {
        if(this->len == 0)
        {
            throw exception() ;
        }
        int s = 0 ;
        iterator its = iterator(this, s) ;
        return its ;
    }
  
public :
    //迭代器
    class iterator{

    public : 
        mystring* it;
        int index ;

    public :
        
        iterator(){ it = new mystring() ; index = 0 ;}
        
        iterator(const mystring* str, int i)
        {
            if(i > str->len || i < 0)
            {
                throw exception() ;
            }
            it = new mystring(*str) ;
            it->len = str->len ;
            this->index = i ;
        }
        
        ~iterator()
        {
            delete it ;
            it = NULL ;
            index = 0 ;
        }
    
    public :
        
        bool operator==(iterator const its)
        {
            if(its.index == this->index&&its.it == this->it)
            {
                return true ;
            }
            return false ;
        }
            
        //此处记一坑
        //返回值为迭代器的引用类型而不是迭代器对象!!!
        iterator& operator=(iterator const s)
        {   
            if(s.it == NULL)
            {
                throw exception();
            }
                
            this->index = s.index ;
            this->it = new mystring(*(s.it)) ;
            return *this ;
        }
        
        iterator& operator --()
        {   
            if(it->len < 0)
            {
                throw exception() ;
            }

            else
            {
                this->index -- ;
                return *this  ;
            }
        }
        
        bool operator!=(iterator s)
        {
            return this->index == s.index?false:true ;
        }

        //i++操作 
        void operator++()
        {
            
            if(it->len-1 == this->index)
            {
                throw exception() ;    
            }
            ++this->index ;
        }

        //++i操作
        void operator++(int i)
        {
            i = 1 ;
            if(strlen(this->it->p) < (size_t)this->index)
            {
                throw exception() ;
            }

            this->index += i ;
        }

        char operator*()
        {
           if(it == NULL)
            {
                throw exception() ;
            }
            
            return this->it->p[index];
        }
    };
};

mystring& mystring::operator+=(mystring const s)
{
    if(s.len == 0)
    {
        return *this ;
    }
    else
    {
        char* q = new char[strlen(s.p)+strlen(p)+1] ;
        strcpy(q, p);
        strcat(q, s.p) ;
        free(p) ;
        p = new char[strlen(q)+1];
        strcpy(p, q) ;
        free(q) ;
        return *this ;
    }
}

char* mystring:: c_str()
{
    return p ;
}

int mystring::lastIndexOf(const char& s){
    
    if(len==0){
        return -1;
    }
    for(int i=len-1;i>=0;i--){
        if(p[i]==s)return i;
    }
    return -1;
}

int mystring::length(){
    return len;
}

mystring& mystring::operator+=(const char*s)
{
    if(p == NULL)
    {
        return *this;
    }
    else
    {
        char * q= new char[strlen(s)+strlen(p)+1];
        strcpy(q, p);
        strcat(q, s);
        free(p);
        p = new char[strlen(s)+1] ;
        strcpy(p,s) ;
        len = strlen(p);
        free(q) ;
    }
    return *this ;
}

int mystring::indexof(const char&s){
    for(int i=0;i<len;i++){
        if(p[i]==s){
            return i;
        }
    }
    return -1;
}

bool mystring::operator!=(const mystring&s){
    return strcmp(p,s.p)?true:false;
}

bool mystring ::operator!=(const char*s){
    return strcmp(p,s)?true:false;
}

bool mystring::operator<(const mystring&s){
    if(strcmp(p,s.p)<0){
        return true;
    }
    else{
        return false;
    }
}

bool mystring::operator<(const char*s){ 

    if(strcmp(p,s)>0){
        return false;
    }
    else{
        return true;
    }
}

bool mystring::operator>(const mystring&s){
    
    if(strcmp(p,s.p)>0){
        return true;
    }
    else{
        return false;
    }
}

bool mystring::operator>(const char*s){
    if(strcmp(p,s)>0){
        return true;
    }
    return false;
}
char * mystring::data(){
    return p;
}

bool mystring ::operator==(const mystring&s){
    
    return strcmp(p,s.p)?0:1;
}

bool mystring::operator==(const char *s){
    return strcmp(p,s)?0:1;
}

char mystring::operator[](const int i){
    
    if(i>len){
        cout<<"out of index"<<endl;
        exit(1);
    }
    else{
        return p[i];
    }
}

ostream&operator<<(ostream& out,const mystring &s){
    out<<s.p;
    return out;
}

istream&operator>>(istream&in,mystring &s){

    cin>>s.p;
    return in;
}
mystring ::mystring(){
    
    len = 0 ;
    p = new char[len+1];
    strcpy(p,"");
}
mystring::~mystring(){

    len = 0; 
    delete[]p;
    p =NULL;
}
mystring& mystring::operator=(mystring const&s){
    
    len = s.len ;
    p = new char[len+1];
    strcpy(p,s.p);
    return *this;
}

mystring& mystring::operator=(const char *s){

    if(!strcmp(s,"")||s==NULL){
        len = 0 ;
        p = new char[len+1];
        strcpy(p,"");
    }

    else{
        len = strlen(s);
        p = new char[len+1];
        strcpy(p,s);
    }

    return *this;
}

char* mystring :: substr(int start, int end)
{   

    if((end-start) < 0|| end > len)
    {
        return NULL ;
    }

    char *q ; 
    q = (char* )malloc (end-start+3);
    strncpy(q, p+start, end-start) ;
    return q ;
}

char* mystring ::  substr(int start)
{   
    if(start < 0 || start > len)
    {
        throw exception() ;
    }   
    return p+start ;
}

mystring::mystring(const char*s){

    if(!strcmp(s,"")||s==NULL){
        len = 0 ;
        p = new char[len+1];
    }
    else{
        len= strlen(s);
        p = new char[len+1];
        strcpy(p,s);
    }
}

mystring :: mystring(mystring const& s)
{
    if(s.len == 0)
    {
        p = NULL ;
    }
    int len = strlen(s.p) ;
    p = new char[len+1] ;
    strcpy(p, s.p) ;
}

测试

#include"mystring.h"
int main()
{
    mystring s = "changkec" ;
    mystring ss = s ;
    
    cout << s << endl ;
    cout << s[1] <

你可能感兴趣的:(c++学习)