在C++程序设计过程中,内存泄漏和野生指针是内存中最常见的错误,这两个问题实际上是由对象的生命周期管理不当造成的,今天为你详细解析C++临时性对象的生命周期,一起跟着武林技术频道小编来看看吧!
有关临时对象的生命周期有三种情况:
1)一般情况:临时性对象的被摧毁,应该是对完整表达式(full-expression)求值过程中的最后一个步骤。该完整表达式造成临时对象的产生。
实例代码如下:
运行结果为:
2)凡含有表达式执行结果的临时性对象,应该存留到object的初始化操作完成为止。
示例代码如下:
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)结束——视哪一种情况先到达而定。
示例代码如下:
运行结果:
准确来说,生命周期其实也是很实用的,今天武林技术频道小编详细解析C++临时性对象的生命周期,希望对你有帮助,也希望大家继续支持武林技术频道!
新闻热点
疑难解答
图片精选