浅拷贝:简单的赋值拷贝操作
深拷贝:在堆区重新申请空间,进行拷贝操作
如果属性有在堆区开辟的,一定要自己提供拷贝构造函数,防止浅拷贝带来的问题;
例子:设类里面有一个指针成员指向一块堆区地址,那么当对象1的数值按照系统默认拷贝构造函数的方式赋值给对象2,那么变量1与变量2里指针成员指向的是同一块堆区的空间,当对象1与对象2被销毁的时候,都会执行析构函数,那么析构函数内释放空间的语句会被执行两次,这样会使得同一块内存空间被释放两次,C++编译器会抛出异常。
解决方案就是:深拷贝---简而言之就是在拷贝函数内部添加一个开辟空间的语句;
代码如下:
最关键的是:有参构造函数部分,成员身高变量开辟在堆区上
persion(int age,int heigh)
{
cout << "有参拷贝构造函数" << endl;
m_age = age;
m_heigh = new int(heigh);
}
析构函数部分,记得释放堆区空间
~persion()
{
cout << "析构函数调用" << endl;
//释放堆区空间
if (m_heigh != NULL)
{
delete m_heigh;
m_heigh = NULL;
}
}
然后采用拷贝构造函数,将对象1的值赋值给对象2
//实例化第一个对象,通过有参构造函数的方法赋值
persion persion1(18, 180);
persion persion2(persion1);
这样代码会有问题,解决方案就是构建自己的深拷贝构造函数!
persion(const persion& persionn)
{
cout << "深拷贝构造函数调用" << endl;
m_age = persionn.m_age;
//m_heigh = persionn.m_heigh;//这是C++默认的拷贝构造函数
m_heigh = new int(*persionn.m_heigh);
}
完整代码如下:
#include <iostream>
using namespace std;
class persion
{
private:
int m_age;
int* m_heigh;
public:
persion()
{
cout << "无参构造函数" << endl;
}
persion(int age, int heigh)
{
cout << "有参构造函数" << endl;
m_age = age;
m_heigh = new int(heigh);
}
persion(const persion& persionn)
{
cout << "深拷贝构造函数调用" << endl;
m_age = persionn.m_age;
//m_heigh = persionn.m_heigh;//这是C++默认的拷贝构造函数
m_heigh = new int(*persionn.m_heigh);
}
~persion()
{
cout << "析构函数调用" << endl;
//释放堆区空间
if (m_heigh != NULL)
{
delete m_heigh;
m_heigh = NULL;
}
}
};
int main()
{
//实例化第一个对象,通过有参构造函数的方法赋值
persion persion1(18, 180);
persion persion2(persion1);
system("pause");
return 0;
}
如果属性有在堆区开辟的,一定要自己提供拷贝构造函数,防止浅拷贝带来的问题;