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;
}
运行结果:
此时,运行就没有问题了。