以上代码的运行结果:
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