2018/2/17
C++
1.为什么要使用副本构造器
在程序中可以把一个对象赋值给另一个类型相同的对象,通过逐位赋值的方法把源对象赋值给目标对象,
但是如果成员变量为指针时,经过赋值后将会有两个指向同一个地址的指针实例,当删除其中一个指针时,
另一个指针也会引用函数,从而造成不必要的麻烦;
2.解决方案
1.采用了=运算符的重载(增加了判断指针是否相同)
2.重新定义了副本构造器()
#include<iostream>
#include<string>
using namespace std;
class MyClass
{
public:
MyClass(int *p);//声明构造器
MyClass(const MyClass &rhs);//声明副本构造器
~MyClass();//声明析构器
MyClass &operator=(const MyClass &rhs);//实现运算符的重载
void print();
private:
int *ptr;
};
MyClass::MyClass(int *p)
{
cout << "进入主构造器\n";
ptr = p;
cout << "离开主构造器\n";
}
MyClass::MyClass(const MyClass &rhs)
{
cout << "进入副本构造器\n";
*this = rhs;
cout << "离开副本构造器\n";
}
MyClass::~MyClass()
{
cout << "进入析构器\n";
delete ptr;
cout << "离开析构器\n";
}
MyClass&MyClass::operator=(const MyClass &rhs)
{
cout << "进入赋值语句重载\n";
if (this != &rhs)
{
delete ptr;
ptr = new int;//申请一块新空间
*ptr = *rhs.ptr;
}
else
{
cout << "赋值号两边为同一个对象,不做处理\n";
}
return *this;
}
void MyClass::print()
{
cout << *ptr << endl;
}
int main()
{
MyClass obj1(new int(1));
MyClass obj2(new int(2));
obj2 = obj1;
obj1.print();
obj2.print();
cout << "********************************\n";
/*正确用法*/
MyClass obj3(new int(3));
MyClass obj4 = obj3;//等号重载
obj3.print();
obj4.print();
cout << "********************************\n";
MyClass obj5(new int(5));
obj5 = obj5;
obj5.print();
system("pause");
}