C++深拷贝与浅拷贝

C++深拷贝与浅拷贝

#include<iostream>
#include<string>

using namespace std;

//深拷贝与浅拷贝
//浅拷贝就是利用默认的拷贝函数,容易带来堆区的内存重复释放问题

class Person {
	

public:
	int m_Age;
	int *m_Height;
	Person() {
		cout << "Person的默认构造函数调用" << endl;

	}
	Person(int age , int height) {
		m_Age = age;
		m_Height= new int(height);
		cout << "Person的有参构造函数调用" << endl;

	}
	Person(const Person &p) {
		cout << "Person拷贝构造函数的调用" << endl;
		m_Age = p.m_Age;
		//m_Height = p.m_Height; 编译器默认实现就是这行代码
		//深拷贝操作
		m_Height = new int(*p.m_Height);
	}
	~Person() {
		//析构代码将我们堆区开辟的数据做释放的操作
		if (m_Height != NULL) {
			delete	m_Height;
			m_Height = NULL;
		}
		cout << "Person的析构函数调用" << endl;

	}

};
void test01() {
	Person p1(18,160);
	cout << "p1的年龄为:" <<p1.m_Age<<"身高为:"<<*p1.m_Height<< endl;
	Person p2(p1);
	cout << "p2的年龄为:" << p1.m_Age<<"身高为:" << *p1.m_Height << endl;
}
int main() {
	test01();


	system("pause");
	return 0;
}

不进行深拷贝即利用编译器默认的拷贝函数会带来堆内存重复释放的问题

如析构函数中所写,拷贝函数和构造函数先后释放了同一堆的内存,然而堆内存在第一次已经释放完毕,导致第二次报错、

自己写的拷贝函数重新开辟新的内存空间为深拷贝

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NAND_LU

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值