浅拷贝:简单的赋值拷贝操作
---->浅拷贝的文字说明很简单,但是理解却不够直接,我们直接上代码
#include<iostream>
using namespace std;
//浅拷贝:简单的赋值拷贝操作
class Student
{
public:
Student()
{
cout << "Student默认构造函数的调用" << endl;
}
Student(int age)
{
m_age = age;
cout << "Student有参构造函数的调用" << endl;
}
~Student()
{
cout << "Student的析构函数调用" << endl;
}
int m_age;
};
void test01(void)
{
Student p1(28);
cout << "p1的年龄是:" << p1.m_age << endl;
Student p2(p1);
cout << "p2的年龄是:" << p2.m_age << endl;
}
int main()
{
test01();
system("pause");
return 0;
}
根据上述代码进行测试 ,能够让我们对浅拷贝有非常直观的感受
现在对代码进行一点的改动,进入到深拷贝的学习中
添加一个类属性(整形指针变量m_height),用new开辟到堆区,把由new开辟的地址存到m_height,
调用有参构造函数。
Student(int age,int height)
{
m_height = new int(height);
m_age = age;
cout << "Student有参构造函数的调用" << endl;
}
~Student()
{
cout << "Student的析构函数调用" << endl;
}
int m_age;
int* m_height;
};
void test01(void)
{
Student p1(28,167);
cout << "p1的年龄是:" << p1.m_age <<" 身高是:" <<*p1.m_height<< endl;
Student p2(p1);
cout << "p2的年龄是:" << p2.m_age <<" 身高是:"<<*p2.m_height<< endl;
}
上面只呈现有改动的代码,其余代码与浅拷贝代码一致
改动后的代码输出无误,能够正常输出,但是存在问题,我们只用new在堆区开辟了内存,但是我们用完并未用delete释放掉
使用delete释放掉由new申请的内存,这时我们也能体会到析构函数的用途了
//析构函数
~Student()
{
//析构代码,将堆区开辟数据做释放操作
if (m_height != NULL)
{
delete m_height;
m_height = NULL;
}
cout << "Student的析构函数调用" << endl;
}
再次运行代码,可这次程序崩掉了
-->由于类对象p1和p2都要释放同一片内存空间,p2先释放m_height的空间,其空间不存在,当p1再去释放m_height这块内存空间时,已经找不到了,导致程序崩掉
用深拷贝来解决这个问题
//自己实现拷贝构造函数,解决浅拷贝带来的问题
Person(const Person& p)
{
m_age=p.m_age;
m_height=new int(*p.m_height);
//m_height=p.m_height编译器默认实现的,也就是浅拷贝操作
}
所以深拷贝就是在堆区重新申请空间,进行拷贝操作
这篇blog到这里就结束了🥳🥳🥳
如有错,还望给位大大指出❤️❤️❤️
创作不易,还望各位多多支持😘😘🥰🫶🤗