《函數調用時參數、返回值所做的優化處理+編譯器NRV優化》

摘要:
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的賦值運算符函數的重載。

詳解:
這裏寫圖片描述

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