• string类的实现


    #include<iostream>
    using namespace std;

    class String
    {
    friend ostream& operator<<(ostream& out,const String& str) //输出操作符重载
    {
    return str.Print(out);
    }
    public:
    String(const char *str = 0);// 普通构造函数
    String(const String &other); // 拷贝构造函数
    ~String(void) { delete [] data_; }// 析构函数
    String& operator=(const String &other);// 赋值函数
    char* data(void) const { return data_; }
    private:
    ostream& Print(ostream& out) const;
    char *data_;// 用于保存字符串
    };

    //赋值操作符首先要注意是不是自己赋给自己,如果是这样的话什么也不做,把自己返回即可。

    //其次就是别人赋值给自己,这时首先要自己把原来的值扔到,根据别人的大小开辟一块空间

    //准备盛放别人的内容,最后不要忘了返回对自己的引用。

    String& String::operator =(const String& other)
    {
    if(this!=&other)
    {
    delete [] data_;
    size_t length=strlen(other.data());
    data_=new char[length+1];
    strcpy_s(data_,length+1,other.data());
    }
    return *this;
    }

    //复制构造函数总是发生在构造阶段,所以此时成员data_还没有空间可以使用,应该先根据别

    //人空间的大小开辟好空间,然后在把别人的内容拷贝进来。

    String::String(const String &other)
    {
    size_t length=strlen(other.data());
    data_=new char[length+1];
    strcpy_s(data_,length+1,other.data());
    }

    //由于输出操作符通常写成类的友元函数,这样就可以写类似cout<<s;如果不是这样使用起来就会

    //很奇怪,比如可能是s.print()之类,无法像cout<<s<<s1<<endl;那样和标准库完美结合,甚至如果

    //你写了一个ostream& operator<<(ostream& out,const String& str)忘了加上友元声明,编译器

    //会认为你是重载了一元移位操作符<<,而且参数还加多了。

    //输出操作符的经典写法就像本文这样,另加一个Print成员函数来完成干活的功能让<<来调用,之所

    //以返回ostream& 也是和C++语言内建操作符机制保持一致,这样就可以写cout<<s<<s1<<endl;而不是

    //cout<<s;cout<<s1;cout<<endl;

    ostream& String::Print(ostream& out) const
    {
    out<<data_;
    return out;
    }

    //此构造函数可以支持隐式类型转换比如你可以这样创建一个String对象 String s("Hello World !");此语句

    //就是在调用这个构造函数,另外String s="Hello World !";会被解释成String s=Sting("Hello World !");先

    //根据字符数组构造一个临时String对象(此对象在这条语句执行完之后就被析构),并紧接着调用String的赋值

    //操作符重载函数

    String::String(const char *str) // 6分
    {
    if(str==NULL)
    {
    data_=new char[1];// 若能加 NULL 判断则更好
    *data_='\0';
    }
    else
    {
    size_t length = strlen(str);
    data_ = new char[length+1]; // 若能加 NULL 判断则更好
    strcpy_s(data_,length+1, str);
    }
    }

    void main()
    {
    char* p="Hello World !";
    String s(p);
    cout<<s<<endl;
    String s1("How are you ?");
    cout<<s1<<endl;
    s1=s;
    cout<<s<<endl<<s1<<endl;
    s=s=s1;
    cout<<s<<endl<<s1<<endl;
    }

    ------------

    好丢脸啊,我竟然以为strcpy是为string定制的.......

    其实它是char *复制的!!!!!

    strcpy系列根本就不用加<string.h>的头文件!!!

  • 相关阅读:
    CentOS7 安装Docker 18.09.5
    CentOS7 安装Jenkins 2.164.2
    Python3从零开始爬取今日头条的新闻【一、开发环境搭建】
    Win10 安装Oracle11g2、配置PL/SQL Developer11环境
    IDEA 使用Mybatis效率飞起来的必备工具:MybatisCodeHelperPro 最新破解版,亲测可用!
    Navicat Premium 12 (64位)实现连接Oracle 11 (64位)
    VMware14 安装CentOS7 实现宿主机ping通虚拟机、虚拟机ping通宿主机、虚拟机能上网且能ping通百度
    Java中util.Date通过mybatis向数据库中datetime的操作!
    Java中try-catch-finally语句中return的执行顺序总结
    java中this用法总结
  • 原文地址:https://www.cnblogs.com/zhiweiyouzhishenghuo/p/5005536.html
Copyright © 2020-2023  润新知