string类(c++)

       string类是c++默认提供的,但是了解string类的写法也是非常重要的,面试中有许多关于string类的题目,string类能够考察c++类和对象的掌握程度,一定程度上也考察了面试者的编程能力。

  

      下面是string类的一些基本功能,由于面试的时间很短,在这极短的时间内全部实现string类的功能是不可能的,我们可以实现最基本的功能,类中的构造函数、析构函数、赋值,复制的功能。



class String
{
public:
    String()     //无参构造函数
       :_str(new char[1])    
   {
        _str[0] = '\0';
    }
    
    String(const char * str)     //构造函数
        :_str(new char[strlen(str)+1])  
    //多开辟一个字符的空间,因为strcpy函数会将'\0'也进行拷贝,而strlen不计算'\0';
    {
        strcpy(_str, str);
    }
    
    //String(const String & s)    //拷贝构造函数
    // :_str(new char[strlen(s._str)+1])
    //{
    // strcpy(_str, s._str);
    //}
    
    //现代写法
    String(const String & s)
        :_str(NULL)
    {
        String tmp(s._str);
        swap(_str, tmp._str);
    }
    
    ~String()    //析构函数
    {
        if (_str != NULL)
        {
            delete[] _str;
            _str = NULL;
            _size = 0;
            _capaciy = 0;
        }
    }
    
 //String operator==(const String & s)   //字符串相等(先开辟空间,然后释放,防止内存泄漏)
 //{
 // if (this != &s)
 // {
 //  char * tmp = new char[strlen(s._str) + 1];
 //  strcpy(_str, s._str);
 //  delete[] _str;
 // }
 //}
 
 //现代写法
    String operator==(String s)
    {
        swap(_str, s._str);
        return *this;
    }
    
    String operator<(const String & s)   //字符串小于
    {
        char *tmp = s._str;
        while (_str != '\0' && tmp != '\0')
        {       
            if (_str == tmp)
            {
                _str++;
                tmp++;
             }
            else if (_str < tmp)
            {
                return *this;
             }
            else
            {
                return s._str;
             }
        }
     }
     
     String operator<=(const String & s)    //字符串小于等于
     {
         char *tmp = s._str;
         if (_str <= tmp)
         {
             return *this;
          }
         else
        {
            return s._str;
         }
     }
     
     String operator>(const String & s)    //字符串大于
     {
         char *tmp = s._str;
         while (_str != '\0' && tmp != '\0')
        {
            if (_str == tmp)
            {
                _str++;
                tmp++;
            }
            else if (_str > tmp)
           {
               return *this;
            }
            else
           {
               return s._str;
           }
       }
    }
    
     String operator>=(const String & s)    //字符串大于等于
    {
        char *tmp = s._str;
        if (_str >= tmp)
        { 
            return *this;
        }
        else
        {
            return s._str;
        }
    }
    
    char operator[](size_t index)
    {
        return _str[index];
     }
     
    void pushBack(char ch)    //压入栈中
    {
        _checkCapacity(_size + 2);
        _str[_size] = ch;
        _str[_size + 1] = '\0';
    }
    
    void popBack()     //出栈
    {
        assert(_str);
        _size--;
        _str[_size] = '\0';
     }
     
    void Insert(size_t pos, char ch)    //插入字符
    {
        assert(pos <= _size);
        //_checkCapacity(_size);
        size_t tmp = _size;
        while (tmp >= pos)
       {
           _str[tmp + 1] = _str[tmp];  //从后往前移动
           tmp--;
        }
        _str[pos] = ch;
        _size++;
     }
     
     void Insert(size_t pos, const char *str)   //插入字符串
     {
         assert(pos <= _size);
         size_t size = strlen(str);      //增容
         _checkCapacity(size + 1 + _size);
         size_t tmp = _size;          //移位
         while (tmp >= pos)
        {
            _str[tmp + size] = _str[tmp];
            tmp--;
         }
         for (size_t i = 0; i < size; i++)    //插入
        {
             _str[pos] = str[i];
             pos++;
         }
         _size += size;
     }
     
     int Find(char ch)    //查找字符
     {
         int pos = 1;
         while (_str != '\0')
        {
            if (*_str == ch)
            {
                return pos;
             }
            else
            {
                _str++;
            }
            pos++;
        }
        return 0;
     }
     
     size_t Find(const char *sub)   //查找子串
     {
         size_t srcIndex = 0;
         size_t subSize = strlen(sub);
         while (srcIndex <= _size - subSize)
         {
             size_t subIndex = 0;
             size_t begin = srcIndex;
             while (_str[begin] == sub[subIndex] && begin < _size && subIndex < subSize)
             {
                 begin++;
                 subIndex++;
             }
             if (subIndex == subSize)
             {
                 return srcIndex;
             }
             srcIndex++;
         }
     }
     
     String & operator+=(const String & s)   //+=
     {
         Insert(_size, s._str);
         return *this;
      }
      
     void Display()
     {
         while (_str != '\0')
        {
            cout << *_str;
            _str++;
        } 
     }
     
private:
    char *_str;
    size_t _size;
    size_t _capaciy;
    
private:
    void _checkCapacity(size_t needsize)
    {
        if (needsize + 1 >= _capaciy)
        {
            _capaciy = needsize > 2 * _capaciy ? needsize : 2 * _capaciy;
            _str = (char *)realloc(_str, _capaciy);
        }
    }
};


本文出自 “无心的执着” 博客,谢绝转载!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值