拷贝构造函数与析构顺序

调用复制构造函数的时机

1,用一个已有对象初始化另一个对象 

void main()

{

Test88 t1;

Test88 t3;

//第一种场景

//1赋值构造函数和=操作是两个不同的概念

//2  赋值构造函数 copy构造函数 也是构造函数

//3 当没有编写拷贝构造函数时,编译器会默认提供一个copy构造函数,执行浅拷贝

//在这个场景之下。t2被创建,并且自动的调用copy构造

Test88 t2 = t1; //对象t2的初始化,等于Test88 t2 ( t1);

t2 = t1; //是对象的=操作

system("pasue");

}

2函数的类类型实参初始化形参时,使用拷贝构造函数,将实参local的数据复制到形参p

Class Location{

};

Void F(Location p){cout<<p.getX()<<p.getY<<endl;}

Void main()

{

Location local;

F(local);

}

3函数返回类类型时,通过复制构造函数建立临时对象  

Location g()

{

Location A(1, 2);

return A; //将局部对象拷贝到匿名对象中,调用拷贝构造函数

}

void main101()

{

Location B;

B = g(); //执行赋值重载运算(如果自己写了运算符重载调用自定义的,如果没有则调用默认),将匿名对象赋值给B,浅复制

 

}

//析构顺序是A-》匿名对象-》B

析构原则:先存在的后析构

匿名对象

void main ()

{

Location B=g();//只调用两次构造与析构,因为c++编译器做了优化,若果是B的初始化,则不用调用B的拷贝构造函数,直接将匿名对象给B

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章