用已存在的类对象去初始化同类另一个对象
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& 类型,引用的别名是和原对象同一快空间,拷贝构造函数根本没返回,返回都不存在,更别说生成临时对象了。