摘要:
c++中創建對象以及銷燬對象時,會自動調用對象的構造、析構函數(默認的或自定義的),因此,當我們在c++中調用函數時應該特別注意傳參以及返回值時的優化處理,以減少構造、析構函數調用時的開銷。同時編譯器也會針對不同情況的函數調用,在不產生錯誤的情況下采用“NRV優化”(函數返回時,不產生臨時變量)。
示例代碼:
#include<iostream>
using namespace std;
class AA
{
public:
AA(int a = 10)
:_a(a)
{
cout << "AA(int a = 10)"<< endl;
}
AA(const AA& s)
:_a(s._a)
{
cout << "AA(const AA& s)" << endl;
}
~AA()
{
cout << "~AA()" << endl;
}
private:
int _a;
};
AA& Test(AA& s)
{
return s;
}
int main()
{
AA a(5);
Test(a);
return 0;
}
傳值調用、傳值返回:
傳引用調用、引用返回:
NRV編譯優化:
//題目:
//Test1中調用了___次AA的拷貝構造函數, ___次AA的賦值運算符函數的重載。
//Test2中調用了___次AA的拷貝構造函數, ___次AA的賦值運算符函數的重載。
//Test3中調用了___次AA的拷貝構造函數, ___次AA的賦值運算符函數的重載。
//
#include<iostream>
using namespace std;
class AA
{};
AA f(AA a)
{
return a;
}
void Test1()
{
AA a1;
a1 = f(a1);
}
void Test2()
{
AA a1;
AA a2 = f(a1);
}
void Test3()
{
AA a1;
AA a2 = f(f(a1));
}
int main()
{
Test1();
Test2();
Test3();
return 0;
}
參考答案:
//Test1中調用了_2_次AA的拷貝構造函數, _1_次AA的賦值運算符函數的重載。
//Test2中調用了_3_次AA的拷貝構造函數, _0_次AA的賦值運算符函數的重載。
//Test3中調用了_5_次AA的拷貝構造函數, _0_次AA的賦值運算符函數的重載。
正確否?
標準答案:
//Test1中調用了_2_次AA的拷貝構造函數, _1_次AA的賦值運算符函數的重載。
//Test2中調用了_2_次AA的拷貝構造函數, _0_次AA的賦值運算符函數的重載。
//Test3中調用了_3_次AA的拷貝構造函數, _0_次AA的賦值運算符函數的重載。
詳解: