C++中的深拷贝与浅拷贝

 浅拷贝只拷贝指针,但拷贝后两个指针指向同一个内存空间;

 深拷贝不但对指针进行拷贝,而且对指针指向的内容进行拷贝,经深拷贝后的指针指向两个不同地址。

 当类成员不包括指针何引用时,浅拷贝并无问题,深拷贝与浅拷贝无太大不同;但当含有指针与引用成员时,当对象的生命周期结束后,浅拷贝会造成同一块内存单元被释放两次,导致内存泄漏。

       可以理解为:浅拷贝类似于文件创建快捷方式,而深拷贝好比文件复制。编译器默认提供的默认拷贝构造函数是浅拷贝,深拷贝的构造函数需自己实现。

浅拷贝实例:

#include <iostream>

using namespace std;

class Example 

public: 
Example(int arraysize) 
{
data = new int[arraysize];
cout<<"构造"<<endl;
} // 假如其中有一段动态分配的内存 
Example(){};
~Example()
{
delete [] data;
cout<<"析构"<<endl;
} // 析构时释放资源
private: 
int* data;
int size; 
};
int main() 

Example a(5);
Example b = a; // 注意这一句
return 0;
}

运行结果:


 此时,程序运行结束时会释放a与b,但由于a与b指向的是同一块内存,这块内存在释放a是就被释放掉了,再到释放b时,

就会导致内存泄露,程序运行出错。


深拷贝实例:

#include <iostream>
using namespace std;
class Example 

public: 
Example(int arraysize) 
{
data = new int[arraysize];
cout<<"构造"<<endl;
} // 假如其中有一段动态分配的内存 
Example(){};
Example(const Example& _A) : size(_A.size)
{
data = new int[size];
} // 深拷贝
~Example()
{
delete [] data;
cout<<"析构"<<endl;
} // 析构时释放资源
private: 
int* data;
int size; 
};
int main() 

Example a(5);
Example b = a; // 注意这一句
return 0;
}

运行结果:


此时,运行就没有问题了。

猜你喜欢

转载自blog.csdn.net/ll596214569/article/details/79271715