以上代码的运行结果:
a address = 0038C248
*a value = 1
a address = 0038C248
*a value = -17891602
该代码使用了默认的拷贝构造函数。也是浅(bitwise)拷贝,test和test2中指针a指向堆中同一地址。当test析构时候,释放堆中内存,test2中的指针a将成为悬浮指针。浅拷贝还可能出现的问题:由于使用同一堆,一个对象对堆上内容的改变,会影响另一个对象。
加入拷贝构造函数如下:仍然是浅拷贝。结果与上面相同。
Test(Test &tem){ a = tem.a; };
若将拷贝构造函数实现改为如下函数:则为深拷贝,在拷贝的过程中对于指针进行重新开辟内存。
Test(Test &tem){ a = new(int) ;*a = *(tem.a); };
运行结果如下:
a address = 0038C248
*a value = 1
a address = 0038C320
*a value = 1
本文通过一个C++示例详细解释了浅拷贝与深拷贝的区别。浅拷贝会导致对象间共享数据,可能引发悬挂指针等问题;而深拷贝确保每个对象拥有独立的数据副本,避免了这些问题。
6083

被折叠的 条评论
为什么被折叠?



