C++中拷贝构造函数调用时机通常有三种情况
- 使用一个已经创建完毕的对象来初始化一个新对象
- 值传递的方式给函数参数传值
- 以值方式返回局部对象
#include<iostream>
using namespace std;
//拷贝构造函数调用时机
class Person {
public:
Person() {
cout << "Person默认构造函数的调用" << endl;
}
Person(int age) {
cout << "Person有参构造函数的调用" << endl;
m_Age = age;
}
Person(const Person& p) {
cout << "Person拷贝构造函数的调用" << endl;
m_Age = p.m_Age;
}
~Person() {
cout << "Person析构函数的调用" << endl;
}
int m_Age;
};
//1、使用一个已经创建完毕的对象来初始化一个新对象
void test01() {
Person p1(20);
Person p2(p1);
cout << "p2的年龄为:" << p2.m_Age << endl;
}
//2、值传递的方式给函数参数传值
void doWork(Person p) {
}
void test02() {
Person p;
doWork(p);
}
//3、以值方式返回局部对象
Person doWork2() {
Person p1;
cout << (int*)&p1 << endl;
return p1;
}
void test03() {
Person p = doWork2();
cout << (int*)&p << endl;
}
int main() {
//test01();
//test02();
test03();
system("pause");
return 0;
}
1.使用一个已经创建完毕的对象来初始化一个新对象
void test01() {
Person p1(20);
Person p2(p1);
cout << "p2的年龄为:" << p2.m_Age << endl;
}
运行结果
p2 拷贝了 p1 因此调用拷贝构造函数
2.值传递的方式给函数参数传值
//定义一个函数
void doWork(Person p) {
}
//以值传递的方式给函数参数传值
void test02() {
Person p;
doWork(p);
}
运行结果
为什么会调用拷贝构造函数?
因为值传递的本质是拷贝一个临时的副本来存储我们传入的变量,因此在test02运行时会调用拷贝构造函数
3.以值方式返回局部对象
//创建一个函数,并以值方式返回局部对象
Person doWork2() {
Person p1;
cout << (int*)&p1 << endl;
return p1;
}
//创建一个对象接收doWork2的返回值
void test03() {
Person p = doWork2();
cout << (int*)&p << endl;
}
运行结果
为什么会调用拷贝构造函数?
局部对象在函数运行完之后就会被释放,但是以值方式返回,返回的并不是p1本身,而是根据p1拷贝一个新的对象在返回给test03,因此会调用拷贝构造函数。并且,doWork2中p1的地址与test03中p的地址不同也间接的表现了,并不是直接把p1传给了p,而是拷贝了一个p1再传给p