深浅拷贝是面试经典问题,也是常见的一个坑
浅拷贝:简单的赋值拷贝操作
深拷贝:在堆区重新申请空间,进行拷贝操作
如果属性有在堆区开辟的,一定要自己提供拷贝构造函数,防止浅拷贝带来的内存重复释放问题
示例
原代码
#include<iostream>
using namespace std;
//深拷贝与浅拷贝
class Person
{
public:
Person()
{
cout << "Person的默认构造函数调用" << endl;
}
Person(int age, int height)
{
m_Age = age;
m_Height = new int(height);//把身高这个数据创建在堆区,返回的是个int类型的指针,用m_Height接收
cout << "Person的有参构造函数调用" << endl;
}
//自己实现拷贝构造函数 解决浅拷贝带来的内存重复释放问题
Person(const Person& p)
{
cout << "Person 拷贝构造函数的调用" << endl;
/*m_Age = p.m_Age;
m_Height = p.m_Height;
这两行代码都是编译器提供的拷贝构造函数里的语句,只是简单的浅拷贝,赋值操作而已 */
m_Age = p.m_Age;
//深拷贝的操作
m_Height = new int(*p.m_Height);
}
~Person()
{
//析构代码,将堆区开辟的数据做释放操作
if (m_Height != NULL)
{
delete m_Height;//释放在堆区创建的数据
m_Height = NULL;//防止野指针出现,将指针致空
}
cout << "Person的析构函数调用" << endl;
}
int m_Age;//年龄
int* m_Height;//身高
};
void test01()
{
Person p1(18, 160);
cout << "p1的年龄为: " << p1.m_Age << " 身高为: " << *p1.m_Height << endl;
Person p2(p1);
cout << "p2的年龄为: " << p2.m_Age << " 身高为: " << *p2.m_Height << endl;
}
int main()
{
test01();
system("pause");
return 0;
}
运行结果