C++临时性对象的生命周期详细解析

时间:2021-05-20

有关临时对象的生命周期有三种情况:

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;
}

运行结果为:



2)凡含有表达式执行结果的临时性对象,应该存留到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;
}

运行结果为:




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的参数上(而不是返回值)。
//这个引用在f()返回的时候就结束了,但是临时对象未必销毁。
cout << "-------------------" << endl;

return 0;
}

运行结果:

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章