test的默认构造函数为t1、t3各调用了一次,因此t1、t3各有一块int大小的内存。
其中test t2 = t1;是复制初始化,没有调用默认的构造函数,也就是说t2并没有申请一个int大小的内存,复制初始化进行的操作实际上是t2.pI = t1.pI。
t3 = t2; 是复制赋值,t3先调用了默认构造函数后,执行t3.pI = t2.pI赋值操作。
以上代码存在的问题是:
1、t3构造函数申请的一个int大小的内存丢失了,它不会被析构函数回收
2、析构函数会为t1、t2、t3各调用一次,但每次回收的内存都是t1构造函数所申请的内存,这会产生致命错误。
代码更正:
test t2 = t1; 会调用 test (const test & t) 构造函数
t3 = t2; 会调用重载的=操作符。