自定义实现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;
    */
}

时间: 2024-10-13 00:01:38

自定义实现String类的相关文章

自定义String类,并且实现在STL容器中添加自定义的类型

13.44 编写标准库string类的简化版本,命名String.你的类应该至少有一个默认构造函数和一个接受C风格字符串指针参数的构造函数.使用allocator为你的String类分配所需内存. 13.47 添加拷贝构造函数和拷贝赋值运算符,并添加打印语句,则每次函数执行时打印一条信息. 13.48 定义一个vector<String>并在其上多次调用push_back.运行程序,观察String被拷贝了多少次. #include<iostream> #include<st

C++的string类

关于头文件cstring,提供了strlen及很多与字符串相关的函数的声明. 头文件string,要使用string类,必须在程序中包含头文件string,string类位于std中,必须提供一条using编译指令,或者使用std::string来引用它. 1.string类的使用: 不能将一个数组赋给另一个数组,但可以将一个string对象赋给另一个string对象. size()是string类的一个方法.可以将C++里边的string类理解成类型,我觉的可以理解成,创建:一个新类型,就像j

mybatis自定义枚举转换类

mybatis提供了 EnumTypeHandler和EnumOrdinalTypeHandler完成枚举类型的转换,两者的功能已经基本满足了日常的使用.但是可能有这 样的需求:由于某种原因,我们不想使用枚举的name和ordinal作为数据存储字段.mybatis的自定义转换类出现了. 示例 使用一段代码,将枚举类EnumStatus中的code属性存储到数据库对应字段statusCustom. 自定义转换类 package com.sg.util.typehandler; import ja

ASP.Net string 类的扩展方法 [转]

string 类的扩展方法列表(基本相同于 IEnumerable<T> 接口的成员列表): Aggregate<>     //累加 All<>        //是否都满足条件 Any<>        //是否有一个满足条件 AsEnumerable<>  // AsParallel<>    // AsQueryable<>    // Average<>      //平均值 Cast<>

基于数组实现Java 自定义Stack栈类及应用

栈是存放对象的一种特殊容器,在插入与删除对象时,这种结构遵循后进先出( Last-in-first-out,LIFO)的原则.java本身是有自带Stack类包,为了达到学习目的已经更好深入了解stack栈,自己动手自建java stack类是个很好的学习开始: 自建Java Stack 类 Stack 类: 1 package com.stack; 2 3 import java.util.ArrayList; 4 import java.util.Arrays; 5 6 /** 7 * St

自定义圆形工具类

1.自定义圆形工具类 CircleImageViewUtil.java 关键点:可以自持缩放 package com.example.circleimageviewdemo; import android.content.Context; import android.graphics.Bitmap; import android.graphics.Bitmap.Config; import android.graphics.Canvas; import android.graphics.Col

c++ --&gt; string类字符串

一.string类字符串的介绍 在程序设计中, 字符串的使用十分频繁, C语言类型字符串(简称C-串)在使用与字符串的处理上较为复杂, C++为了在程序设计中更加方便的使用字符串特新增了一种string类型的字符串. string类字符串为STL(Standard Template Library, 标准模板库)中的一种自定义的数据类型, 相对于C-串来说string类型串具有一些明显的优势, 首先, 它在内存使用上是自动的, 需要多少, 开辟多少, 并且能够根据字符串大小的变化自动调整所开辟的

C++ string类及其函数的讲解

文章来源于:http://www.cnblogs.com/hailexuexi/archive/2012/02/01/2334183.html C++中string是标准库中一种容器,相当于保存元素类型为char的vector容器(自己理解),这个类提供了相当丰富的函数来完成对字符串操作,以及与C风格字符串之间转换,下面是对string一些总结<引用> 一,C语言的字符串 在C语言里,对字符串的处理一项都是一件比较痛苦的事情,因为通常在实现字符串的操作的时候都会用到最不容易驾驭的类型——指针.

Java String类型值真的不可改变吗?

1.Java String 可以改变吗? 一直认为java 中String类型的值不能修改,主要是因为String是final的,而且里面没有设置值的set方法.但是可以通过反射机制改变值. 例1 public class Test { public static void main(String[] args) throws Exception { String s="0123456789"; System.out.println("改变前:s=" + s); F