【C++】产生拷贝构造的三种形式

用已存在的类对象去初始化同类另一个对象

Date d1;
Date d2(d1);
Date d3 = d2;	//也会调用拷贝构造

  • 注意赋值号这种拷贝构造,我们说了是已存在的对象初始化另一个未初始化的对象才叫拷贝构造,这与我们后面说的赋值重载有区别。赋值重载是两个对象都已经初始化。
  • 可以看到在实例化对象d2和d3的时候都去调用了拷贝构造,最后它们初始化后的结果都是一样的
    在这里插入图片描述

当函数类的形参是对象,调用函数形参和实参进行结合

void func(Date d)	//形参是类的对象
{
	d.Print();
}

int main(void)
{
	Date d1;
	func(d1);	//传参引发拷贝构造
	
	return 0;
}

  • 我们在类和对象中里面说过,自定义类型传参调用就会发生拷贝构造,形参是实参因为的拷贝,那么这里就调用拷贝构造,然后当func函数执行完后,这个对象d就被析构,然后当main函数执行完后,对象d1也被析构
  • 再次提醒,传引用调用是不会开辟空间进行拷贝的,所以拷贝构造函数用传引用调用。
    在这里插入图片描述

当函数的返回值是对象,函数执行完成返回调用者时

Date func2()
{
	Date d(2023, 3, 24);
	return d;
}

int main(void)
{
	Date d1 = func2();
	d1.Print();

	return 0;
}

  • 可以看到,这一种方式也会引发拷贝构造,当函数内部返回一个Date类的对象时,此时外界再使用Date类型的对象去接收时,就会引发拷贝构造。通过调试可以观察到外界的对象d1确实是以函数内部通过有参构造初始化完后的对象进行拷贝的
    在这里插入图片描述
  • 注意这里不会用临时对象赋值d2,这里是调用的拷贝构造函数返回,而拷贝构造函数参数是const& 类型,引用的别名是和原对象同一快空间,拷贝构造函数根本没返回,返回都不存在,更别说生成临时对象了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值