C++臨時(shí)性對象的生命周期詳細(xì)解析
1)一般情況:臨時(shí)性對象的被摧毀,應(yīng)該是對完整表達(dá)式(full-expression)求值過程中的最后一個(gè)步驟。該完整表達(dá)式造成臨時(shí)對象的產(chǎn)生。
實(shí)例代碼如下:
#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; //運(yùn)行到這里,a1 + a2產(chǎn)生的臨時(shí)變量已經(jīng)被釋放
return 0;
}
運(yùn)行結(jié)果為:

2)凡含有表達(dá)式執(zhí)行結(jié)果的臨時(shí)性對象,應(yīng)該存留到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產(chǎn)生的臨時(shí)變量在a3的賦值操作完成后,才釋放
return 0;
}
運(yùn)行結(jié)果為:

3)如果一個(gè)臨時(shí)性對象被綁定于一個(gè)reference,對象將殘留,直到被初始化之reference的生命結(jié)束,或直到臨時(shí)對象的生命范疇(scope)結(jié)束——視哪一種情況先到達(dá)而定。
示例代碼如下:
#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的生命結(jié)束
cout << f(A()) << endl; //直到臨時(shí)對象的生命范疇(scope)結(jié)束:
//臨時(shí)對象的const引用在f的參數(shù)上(而不是返回值)。
//這個(gè)引用在f()返回的時(shí)候就結(jié)束了,但是臨時(shí)對象未必銷毀。
cout << "-------------------" << endl;
return 0;
}
運(yùn)行結(jié)果:

相關(guān)文章
C語言實(shí)現(xiàn)數(shù)組元素排序方法詳解
這篇文章主要為大家介紹了C語言算法練習(xí)中數(shù)組元素排序的實(shí)現(xiàn)方法,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C語言有一定幫助,需要的可以參考一下2023-02-02OpenCV4 實(shí)現(xiàn)背景分離的詳細(xì)步驟(背景減法模型)
背景分離(BS)是一種通過使用靜態(tài)相機(jī)來生成前景掩碼(即包含屬于場景中的移動對象像素的二進(jìn)制圖像)的常用技術(shù),本文給大家介紹OpenCV4 實(shí)現(xiàn)背景分離的詳細(xì)步驟,需要的朋友可以參考下2021-09-09C語言異或校驗(yàn)算法的項(xiàng)目實(shí)現(xiàn)
異或校驗(yàn)算法(XOR校驗(yàn))是一種簡單的校驗(yàn)算法,用于檢測數(shù)據(jù)在傳輸或存儲過程中是否發(fā)生了錯(cuò)誤,本文主要介紹了C語言異或校驗(yàn)算法的項(xiàng)目實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08C/C++ 實(shí)現(xiàn)簡易HTTP服務(wù)器的示例
這篇文章主要介紹了C/C++ 實(shí)現(xiàn)簡易HTTP服務(wù)器的示例,幫助大家更好的理解和學(xué)習(xí)C/C++編程,感興趣的朋友可以了解下2020-10-10c++使用regex報(bào)錯(cuò)regex_error兩種解決方案
C++正則表達(dá)式是一個(gè)非常強(qiáng)大和實(shí)用的工具,但是使用它們時(shí)需要注意仔細(xì)檢查代碼是否符合語法規(guī)則,這篇文章主要給大家介紹了關(guān)于c++使用regex報(bào)錯(cuò)regex_error的兩種解決方案,需要的朋友可以參考下2024-03-03