自定义字符串String类,分析构造函数,拷贝构造函数,运算符重载以及析构函数等类的基本实现。
构造函数
构造函数分无参构造函数和带参构造函数。
系统会自动生成缺省无参构造函数。当显式实现带参构造函数时,必须同时显式实现无参构造函数,否则无参构造函数会被覆盖。
显式实现构造函数有两种表达:
Ⅰ. String() = default;
String(const char *m_data);
//default表示保留隐式定义成员函数,delete表示删除默认成员函数
Ⅱ. String(const char *m_pData = nullptr);
其中,第二种实现需在函数中对无参(即nullptr)情况进行判断处理。
拷贝构造函数
拷贝构造函数也是构造函数,因此并无函数返回值。缺省拷贝构造函数是浅拷贝的实现。
深拷贝与浅拷贝
深拷贝和浅拷贝最根本的区别在于是否真正获取一个对象的复制实体,而不是引用。
浅拷贝: 只是对基本数据类型进行复制。当类含有指针类型的数据成员时,浅拷贝复制的也仅仅是指针,即指向内容的内存地址,结果就是两个不同的指针指向同一个内存空间;
深拷贝:在堆内存重新申请一块内存空间,对指针指向的内容也进行拷贝。
因此,浅拷贝存在两种隐患:
Ⅰ.若存在指针类型的数据成员,则对其中一个对象进行修改,由于指向同一块内存空间,另一个对象同时被修改。
Ⅱ.当对象生命周期结束调用析构函数时,会对同一块内存空间析构两次,造成内存泄漏。
赋值运算符重载
首先,赋值运算符重载函数声明如下:
String &operator =(const String &str);
为什么返回值和对象形参要用引用传值的方式?
I. 为了避免对象的多次拷贝与析构,提高效率。若采用值传递的方式,在执行return语句的时候,系统会产生一个临时变量