浅拷贝:简单的赋值拷贝
深拷贝:在堆区重新申请空间,进行拷贝操作
1.浅拷贝
首先我们要明白,在你不重写拷贝构造函数时默认的构造函数为浅拷贝,是将值进行拷贝,如下图。
其中默认的拷贝函数代码为
test(const test &p)
{
this.age=p.age;
}
很明显这是一个简单的赋值操作,这也就是一个简单的浅拷贝过程。
2.深拷贝
当我们遇见非要在堆区开辟内存进行存储的情况下,我们来看看会造成什么后果代码如下。(在代码中我们将在析构函数中进行内存的释放)
运行结果
触发了一个断点。这是为什么呢?接下来我们来画图分析。
当代码执行到拷贝构造函数时,进行了默认的浅拷贝也就是如上图所示,将小明height存储的180在堆区的地址赋值给了李华的height。随后执行李华的析构函数进行了height所指向内存的释放。进行到这里也还正常没有出现任何问题。接下来就是关键了,当执行完李华的析构函数就要执行小明的析构函数了,此时小明height说指向的内存任然时刚才李华释放的内存,这个内存本已被释放结果又要被释放此时就产生了冲突。我们在此不得不重新写拷贝构造函数达到我们想要的效果,它的这种形式也就是我们说说的深拷贝。
代码如下: