文章目录
- 1、 代码
- 2、 分析
- 3、运行结果
1、 代码
#include<iostream>
using namespace std;
static int g_count = 1;
class test
{
public://构造函数test(int p=10){ma = p ; cout<<g_count++<<" test(int)"<<endl;}//析构函数~test(){cout<<g_count++<<" ~test()"<<endl;}//拷贝构造函数test (const test &p){ma = p.ma;cout<<g_count++<<" operator(test)"<<endl;}//赋值运算符的重载test& operator=(const test p){ma = p.ma;cout<<g_count++<<" operator = (test)"<<endl;return *this;}
public:int getdata(){return ma;}
private:int ma;
};test getobj(test t)
{int val = t.getdata();test tmp(val);return tmp;
}int main()
{test t1;test t2;t2 = getobj(t1);return 0;
}
2、 分析
1、main函数里 test t1; 毋庸置疑直接调用构造函数;1、test(int)
2、main函数里 test t2; 毋庸置疑直接调用构造函数;2、test(int)
3、t2 = getobj(t1); 调用getobj 将实参t1传给形参t , 此时注意,实参到形参的过程是赋值还是初始化呢,答案是初始化,用一个存在的对象初始化一个新对象,那肯定是调用拷贝构造函数3、operator(test)
4、进入getobj , test tmp(val);生成临时对象,调用构造函数4、test(int)
5、return tmp; 返回数据,返回数据过程是这样的,在调用方的栈空间构造一个临时对象,有tmp拷贝构造完成,生成一个临时对象;5、operator(test)
6、此时已经出了getda()函数的作用域了,函数内的对象开始析构,先析构tmp ,6、~test() , 再析构形参7、~test()
7、t2 = getobj(t1); 用生成的临时对象给t2赋值,调用赋值运算符的重载; 8、 operator = (test)
8、赋值完毕后 , 第5步生成的临时对象开始析构;9、~test()
9、main函数执行完毕,开始析构,先析构t2 , 10、~test() 再析构t1 11、 ~test()