溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++臨時對象的生命周期舉例分析

發(fā)布時間:2021-11-24 10:29:53 來源:億速云 閱讀:162 作者:iii 欄目:互聯(lián)網科技

這篇文章主要介紹“C++臨時對象的生命周期舉例分析”,在日常操作中,相信很多人在C++臨時對象的生命周期舉例分析問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C++臨時對象的生命周期舉例分析”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1)一般情況:臨時性對象的被摧毀,應該是對完整表達式(full-expression)求值過程中的最后一個步驟。該完整表達式造成臨時對象的產生。

例:

#include <iostream>
using namespace std;

class A
{
public:
    A(int i): m_i(i)
    {
        cout << "A(): " << m_i << endl;
    }

    ~A()
    {
        cout << "~A(): " << m_i << endl;
    }

    A operator+(const A& rhs)
    {
        cout << "A operator+(const A& rhs)" << endl;
        return A(m_i + rhs.m_i);
    }

    int m_i;
};

int main()
{
    A a1(1), a2(2);
    a1 + a2;
    cout << "------------------------------------" << endl; //運行到這里,a1 + a2產生的臨時變量已經被釋放
    return 0;
}

運行結果:
A(): 1
A(): 2
A operator+(const A& rhs)
A(): 3
~A(): 3
------------------------------------
~A(): 2
~A(): 1

兩個例外:
2)凡含有表達式執(zhí)行結果的臨時性對象,應該存留到object的初始化操作完成為止。

例:

#include <iostream>
using namespace std;

class A
{
public:
    A(int i = 0): m_i(i)
    {
        cout << "A(): " << m_i << endl;
    }

    ~A()
    {
        cout << "~A(): " << m_i << endl;
    }

    A operator+(const A& rhs)
    {
        cout << "A operator+(const A& rhs)" << endl;
        return A(m_i + rhs.m_i);
    }

    A& operator=(const A& rhs)
    {
        cout << "A& operator=(const A& rhs)" << endl;
        m_i += rhs.m_i;
        return *this;
    }

    int m_i;
};

int main()
{
    A a1(1), a2(2);
    A a3;
    a3 = a1 + a2; //a1 + a2產生的臨時變量在a3的賦值操作完成后,才釋放
    return 0;
}

運行結果:
A(): 1
A(): 2
A(): 0
A operator+(const A& rhs)
A(): 3
A& operator=(const A& rhs)
~A(): 3
~A(): 3
~A(): 2
~A(): 1

3)如果一個臨時性對象被綁定于一個reference,對象將殘留,直到被初始化之reference的生命結束,或直到臨時對象的生命范疇(scope)結束——視哪一種情況先到達而定。

例:

#include <iostream>
using namespace std;

class A
{
friend ostream& operator<<(ostream& os, const A&);
public:
    A()
    {

    }

    A(const A&)
    {
        cout << "A(const A&)" << endl;
    }

    ~A()
    {
        cout << "~A()" << endl;
    }
};

ostream& operator<<(ostream& os, const A&)
{
    os << "ostream& operator<<(ostream& os, const A&)" << endl;
    return os;
}

const A& f(const A& a)
{
    return a;
}

int main(int argc, char* argv[])
{
    {
        const A& a = A();
        cout << "-------------------" << endl;
    }//直到被初始化之reference的生命結束
       
    cout  << f(A()) << endl; //直到臨時對象的生命范疇(scope)結束:
                             //臨時對象的const引用在f的參數(shù)上(而不是返回值)。
                             //這個引用在f()返回的時候就結束了,但是臨時對象未必銷毀。
    cout << "-------------------" << endl;
   
    return 0;
}

運行結果:
-------------------
~A()
ostream& operator<<(ostream& os, const A&)

~A()

到此,關于“C++臨時對象的生命周期舉例分析”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

c++
AI