1、优化规则
用临时对象生成新对象的时候,临时对象被优化掉了,直接按照生成临时对象的方法生成新对象
2、代码
#include<iostream>
using namespace std;
class test
{
public:
//构造函数
test(int p){ma = p ; cout<<"test(int)"<<endl;}
//析构函数
~test(){cout<<"~test()"<<endl;}
//拷贝构造函数
test (const test &p)
{
ma = p.ma;
cout<<"operator(test)"<<endl;
}
//赋值运算符的重载
test& operator=(const test p)
{
ma = p.ma;
cout<<"operator = (test)"<<endl;
}
private:
int ma;
};
int main()
{
test b = test(100);
return 0;
}
3、分析
test b = test(100); 本行代码,若是不优化的话应该这样调用
1、test(100) , 调用构造函数,构造一个临时变量
2、调用赋值运算符的重载,将上面生成的临时变量赋给 b ;
3、因为临时对象的生存周期就是在本行,所以本行执行完毕后会调用析构函数去析构临时对象;
4、函数结束调用析构函数析构b
综上,一共产生了四次函数调用,因为函数调用会产生很多的堆栈,消耗资源较大,编译器进行优化后,只剩下两个函数调用,大大减少了因函数调用而产生的堆栈的开辟和回收。