c++深拷贝和浅拷贝

深拷贝与浅拷贝解析
本文通过自定义类myCopy的实例,深入探讨了深拷贝与浅拷贝的区别。当类中包含指针成员时,如果不自定义拷贝构造函数,编译器提供的默认浅拷贝会导致内存泄漏或程序崩溃。文章详细解释了如何通过实现自己的拷贝构造函数来解决这一问题,确保每个对象拥有独立的数据副本。

深拷贝、浅拷贝的问题出现在:当一个自定义类中出现指针成员时。

考虑一个类myCopy:

#include <iostream>

using namespace std;

class myCopy
{
private:
	int len;
	char * name;

public:
	myCopy(int l, char* n)
	{
		len = l;
		name = new char[len];
		strcpy(name, n);
		cout << "constructor called" << endl;
	}
	~myCopy()
	{
		delete name;
		cout << "destructor called" << endl;
	}
};

int main()
{
	int len = 6;
	char *n = "hello";
	myCopy c1(len, n);   
	myCopy c2 = c1;	   
	cout << "ready to call destructor..." << endl;
    return 0;
}

上面c2 = c1 (把c1复制给c2)是没问题的,因为即便我们没有定义拷贝构造函数,编译器会自动call默认的拷贝构造函数,只不过默认的拷贝构造是浅拷贝:意思是c1在内存中的“hello"并没有真的拷贝一份给c2,只不过是让c2的name指针也指向了c1的“hello", 所以结果就是内存中只有一个”hello",而却又两个指针指向这个内容。

运行结果为:

constructor called
ready to call destructor...
destructor called
*** Error in `/home/fyj/Desktop/cpp/learn/test/Debug/test': double free or corruption (fasttop): 0x0000000000fb5c20 ***

有两个指针,但最后只有一个指针被析构,所有显示错误。

改正方法就是我们自己写一个拷贝构造函数,让“hello"真正地被拷贝一份给c2。

在类中增加:

	myCopy(const myCopy& c)
	{
		len = c.len;
		name = new char[len];
		strcpy(name, c.name);
	}

这样就有两个name指针,各自指向两块”hello"内存,避免问题:

constructor called
ready to call destructor...
destructor called
destructor called
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值