拷贝构造函数调用时机:
1、用已经创建好的对象初始化新的对象;
2、以值传递的方式对函数参数进行传值;
3、以值方式返回局部对象。
#include<iostream>
using namespace std;
class Person
{
public:
Person()
{
cout << "默认构造函数的调用" << endl;
}
Person(int a)
{
cout << "有参函数的调用" << endl;
}
Person(const Person& p)
{
cout << "拷贝构造函数调用" << endl;
}
~Person()
{
cout << "析构函数调用" << endl;
}
int m_Age;
};
//拷贝构造调用时机
//1、用已经创建好的对象来初始化新的对象
void test01()
{
Person p1;
p1.m_Age = 10;
Person p2(p1);
}
//2、以值传递的方式给函数参数传值
void doWork(Person p1) //Person p1 = Person(p) //引用传递不会调用拷贝构造
{
}
void test02()
{
Person p;
p.m_Age = 10;
doWork(p);
}
//3、以值方式返回局部对象
Person doWork2()
{
Person p1;
return p1;
}
void test03()
{
Person p = doWork2();
}
int main(void)
{
//test01();
//test02();
test03();
system("pause");
return 0;
}
Debug下的结果:
Release下的结果:
分析:两种模式下的结果不同。
Release下优化成什么样?
Person p; //不调用默认构造
doWork2(p);
void doWork2(Person & p)
{
Person p1; //拷贝的数据以引用的方式进行传递,因此,操作的p1是之前的p1.
}