学习笔记-c++面向对象程序设计-拷贝构造函数的调用时机

c++中拷贝构造函数调用时机通常有三种情况

        1.使用一个已经创建完毕的对象来初始化一个新对象

        2.值传递的方式给函数参数传值

        3.以值方式返回局部对象

示例

#include<bits/stdc++.h>
using namespace std;
class person
{
public:
	person()
	{
		cout<<"无参构造函数"<<endl;
		m_age=0; 
	}
	
	person(int age)
	{
		cout<<"有参构造函数"<<endl;
		m_age=age; 
	}
	
	person(const person &p)
	{
		cout<<"拷贝构造函数"<<endl;
		m_age=p.m_age; 
	}
	
	//析构函数在释放内存之前调用
	~person()
	{
		cout<<"析构函数"<<endl;	
	} 
	
public:
	int m_age;
}; 

//1.使用一个已经创建完毕的对象来初始化一个新对象
void test01()
{
	person man(100);//p对象已经创建完毕
	person newman(man);//调用拷贝构造函数
	person newman2=newman;//拷贝构造 隐式转换法
	
	//person newman3;
	//newman3=man; 不是调用拷贝构造函数,赋值操作	
} 

//2.值传递的方式给函数参数传值
void dowork(person p1) { }

void test02() 
{
	person p;//无参函数构造
	dowork(p);//相当于person p1=p;	
} 

//3.以值的方式返回局部对象
person dowork2()
{
	person p1;
	cout<<"p1的地址"<<&p1<<endl;
	return p1;//返回的时候会根据p,拷贝一个新的变量	
} 

void test03()
{
	person p3=dowork2();
	cout<<"p3的地址"<<&p3<<endl;
}

int main()
{
	//test01();
	//test02();
	test03();
	
	return 0;
}

 我们可以分析一下运行的结果

为了方便 我们只运行了test03

第一行 无参构造函数 是我们在调用 dowork02的时候 执行了person p1,调用了无参构造函数

第二行 执行 dowork2中 打印p1地址的操作

第三行 当函数dowork02返回p1时 编译器会创建一个临时的变量,然后将p1通过拷贝构造函数给临时变量赋值

 第四行 因为p1是局部变量,存在栈区,当函数dowork2执行完之后 他的内存被释放,p1被析构

第五行 当dowork2执行完之后 程序开始将dowork2返回的临时对象通过拷贝构造函数赋值给p3(这里是通过隐式转换法)。

第六行 当执行完 person p3=dowork2();这行时 临时对象就被析构了。

第七行 程序接下来打印p3的地址

第八行 当test03执行完后,内存被释放,p3被析构

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值