自定义实现String类

自定义实现String类的内容
直接在代码中阐述:附有测试样例
代码:

#include <iostream>
//#include <cstring>
using namespace std;
class String
{
    public:
        //ctor
        String();
        String(const char* s);
        String(const char* s, size_t len);
        String(const String& rhs);
        String(size_t Len);

        String& operator=(const String& rhs);

        //dtor
        ~String();

        //get
        size_t size() const;
        const char* data() const;
        const char* c_str() const;

        // set & get
        char & operator[](size_t index);
        char operator[] (size_t index) const;

        //imp
        String operator +(const String& rhs);
        void operator +=(const String& rhs);


        //输出
        friend ostream& operator <<(ostream& out,const String& rhs);

    private:
        char*  data_;
        size_t len_;
};
    String::String()
        : data_(NULL), len_(0)
    {
        data_ = new char[1];
        data_[0] = '\0';
    }

    String::String(size_t Len)
    {
        data_ = new char[Len+1];
        for(size_t i=0;i<=Len;i++)
        {
            data_[i] = '\0';
        }
    }

    String::String( const char* s )
    {
        size_t i = 0;
        size_t len = 0;
        while(s[i] != '\0')
        {
            i++;
            len++;
        }
        data_ = new char[len+1];

        for(size_t j = 0;j < len;j++)
        {
            data_[j] = s[j];
        }
        data_[len] = '\0';
        len_ = len;
    }

    String::String( const char* s, size_t len )
    {
        data_ = new char[len+1];
        for(size_t k=0;k<len;k++)
        {
            data_[k] = s[k];
        }
        data_[len] = '\0';
        len_ = len;
    }

    String::String( const String& rhs )
    {
        size_t len = rhs.size();
        data_ = new char[len+1];
        for(size_t i=0;i<len;i++)
        {
            data_[i] = rhs.data_[i];
        }
        data_[len] = '\0';
        len_ = len;
    }

    String String::operator +(const String& rhs)
    {
        size_t totalLen = len_ + rhs.len_;
        String tmp(totalLen);
        size_t i,j;
        for(i=0;i<len_;i++)
        {
            tmp[i] = data_[i];
        }
        for(j=0;j<rhs.len_;j++,i++)
        {
            tmp[i] = rhs.data_[j];
        }
        return tmp;
    }

    void String::operator +=(const String& rhs)
    {
        size_t totalLen = len_ + rhs.len_;
        String tmp(totalLen);
        size_t i,j;
        for(i=0;i<len_;i++)
        {
            tmp[i] = data_[i];
        }
        for(j=0;j<rhs.len_;j++,i++)
        {
            tmp[i] = rhs.data_[j];
        }
        *this = tmp;
    }

    String& String::operator=( const String& rhs )
    {
        //比较对象的地址
        if(this == &rhs)
        {
            return *this;
        }

        delete[] data_;
        size_t len = rhs.size();
        data_ = new char[len+1];

        for(size_t i = 0;i < len; i++)
        {
            data_[i] = rhs.data_[i];
        }
        data_[len] = '\0';

        return *this;
    }

    String::~String()
    {
        if(data_)
        {
            delete[] data_;
            data_ = NULL;
        }
        len_ = 0;
    }

    size_t String::size() const
    {
        int i = 0;
        int len_ = 0;
        while(data_[i] != '\0')
        {
            i++;
            len_++;
        }
        return len_;
    }

    const char* String::data() const
    {
        return data_;
    }

    const char* String::c_str() const
    {

        return data_;
    }

    char & String::operator[](size_t index )
    {
        if(index > len_)
        {
            return data_[len_-1];
        }
        else
        {
            return data_[index];
        }
    }
    char String::operator[] (size_t index) const
    {
        if(index > len_)
        {
            return data_[len_-1];
        }
        else
        {
            return data_[index];
        }
    }
    //注意 友员不是成员函数 不用加上String::
    ostream& operator <<(ostream& out,const String& rhs)
    {
        out<< rhs.data_ << endl;
        return out;
    }
int main()
{
    String a("hello",3);
    cout << a ;
    String b("world");
    String c(b);
    cout << c ;
    cout << c[2] <<endl;
    cout << a+b;
    //cout << a << endl;
    //cout << a+b << endl;
    /*
    String a("hello");
    cout << a << endl; //这个是 重载的 <<
    char x[20];
    String c = "wolrd";
    strcpy(x,c.c_str());
    cout << x << endl;
    cout << "Hello world!" << endl;
    return 0;
    */
}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,作为AI语言模型,我无法提供完整的C#代码实现。但是,我可以向您提供一些关于C#自定义字符串的基本原理和方法: C#中的字符串是一个不可变的类型,即一旦创建,就无法修改其内容。因此,要自定义一个可变的字符串类型,您需要创建一个并重载一些运算符和方法。 以下是一些示例代码,可以帮助您开始编写自定义字符串: ``` public class MyString { private char[] buffer; public MyString(string str) { buffer = str.ToCharArray(); } public int Length { get { return buffer.Length; } } public char this[int index] { get { return buffer[index]; } set { buffer[index] = value; } } public override string ToString() { return new string(buffer); } public static MyString operator +(MyString str1, MyString str2) { char[] newBuffer = new char[str1.Length + str2.Length]; str1.buffer.CopyTo(newBuffer, 0); str2.buffer.CopyTo(newBuffer, str1.Length); return new MyString(new string(newBuffer)); } // Other methods and operators can be added here } ``` 在这个示例中,我们定义了一个MyString,它包含一个char数组作为字符串的内部缓冲区。我们还定义了一些属性和方法,例如Length,索引器,ToString等。最重要的是,我们重载了加法运算符,允许我们将两个MyString对象拼接在一起。 当您创建了自定义字符串后,您可以像使用系统字符串一样使用它。例如: ``` MyString str1 = new MyString("Hello"); MyString str2 = new MyString("World"); MyString str3 = str1 + str2; Console.WriteLine(str3); // Output: "HelloWorld" ``` 希望这些示例代码能够帮助您开始编写自定义字符串

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值