当前位置: 首页 > news >正文

【C/C++语言系列】浅拷贝和深拷贝

浅拷贝和深拷贝在面试中经常被问,十分重要。
浅拷贝问题:如果有数据创建在堆区,那么在析构时会出现重复析构的问题。
解决方法:使用深拷贝去解决堆区数据重复释放的问题
观察下面代码,发现浅拷贝问题:

class Person {
public:
	//无参(默认)构造函数
	Person() {
		cout << "无参构造函数!" << endl;
	}
	//有参构造函数
	Person(int age ,int height) {
		
		cout << "有参构造函数!" << endl;

		m_age = age;
		m_height = new int(height);
		
	}

	//析构函数
	~Person() {
		cout << "析构函数!" << endl;
		if (m_height != NULL)
		{
			delete m_height;
		}
	}
public:
	int m_age;
	int* m_height;
};

void test01()
{
	Person p1(18, 180);
	Person p2(p1);   
	cout << "p1的年龄: " << p1.m_age << " 身高: " << *p1.m_height << endl;
	cout << "p2的年龄: " << p2.m_age << " 身高: " << *p2.m_height << endl;
}

int main() {
	test01();
	system("pause");
	return 0;
}

如果不写拷贝构造函数,编译器会自动生成一个浅拷贝的拷贝构造函数:

	//系统自动加的拷贝构造函数  
	Person(const Person& p) {
		cout << "拷贝构造函数!" << endl;
		//如果不利用深拷贝在堆区创建新内存,会导致浅拷贝带来的重复释放堆区问题
		m_age = p.m_age;
		m_height = p.m_height	  //浅拷贝,两个指针指向相同
	}

浅拷贝报错原因:这样两个m_height指针指向同一块内存,它们各自都调用析构函数就会造成堆区数据重复释放。

解决方法深拷贝:重新在堆区创建一块内存,它们的指向不同,单指向的内容相同,这样在析构时分别释放自己的堆区数据。

	//拷贝构造函数  
	Person(const Person& p) {
		cout << "拷贝构造函数!" << endl;
		//如果不利用深拷贝在堆区创建新内存,会导致浅拷贝带来的重复释放堆区问题
		m_age = p.m_age;
		m_height = new int(*p.m_height);  //深拷贝	
	}

相关文章:

  • 动手学深度学习(五)循环神经网络RNN
  • Docker实操:安装MySQL5.7详解(保姆级教程)
  • 求和(2)
  • 北疆自驾旅行规划
  • docker挂载宿主机文件run命令启动报错
  • Docker+PyCharm远程调试环境隔离解决方案
  • Java I/O终极指南:BIO, NIO, AIO深度剖析
  • C++_CH18_构造函数与析构函数
  • 常见的反爬虫和应对方法
  • Lodash的特点和功能
  • Linux(4)--CentOS8虚拟机下联网
  • 在线查看 Android 系统源代码 AOSPXRef and AndroidXRef
  • python的6种常用数据结构
  • Unity射击游戏开发教程:(35)轰炸敌人
  • 系统 IO
  • linux第二课(docker的安装使用)
  • 基于 jenkins 的持续集成、持续部署方案
  • Python模块和包:标准库模块(os, sys, datetime, math等)②
  • k8s常用指令续:
  • 2024低代码平台排名 国内十大主流低代码开发平台
  • 中科飞测将投资超10亿元,在上海张江成立第二总部
  • 袁思达已任中国科学院办公厅主任
  • 崔登荣任国家游泳队总教练
  • 马上评丨岂能为流量拿自己的生命开玩笑
  • 兰州大学教授安成邦加盟复旦大学中国历史地理研究所
  • 复旦大学与上海杨浦共建市东医院