这是我在阅读Effective c++中认为比较重要的部分,下面给出了我对这一节的理解,并写出对应的比较容易理解的代码。
考虑以下代码:
void f() {
Investment* pInv = creatInvestment();
...
...
delete pInv;
}
如果在…区域内抛出异常或出现return,则会导致没有释放资源,导致内存泄漏。
解决此问题的方法可以使用类指针对象autp_ptr或智能指针shared_ptr两种管理对象(managing object)。
一旦管理对象被销毁(例如当对象离开作用域)其析构函数自然会被调用。
auto_ptr和shared_ptr两者都在其析构函数内做delete而不是delete[]操作。
通过拷贝构造或拷贝赋值赋值auto_ptr,会使原来的auto_ptr指向null,而shared_ptr则不会。
#include<memory>
using namespace std;
class Investment {
public:
int i = 10;
virtual void gg() const = 0;
};
class Two :public Investment {
int i = 11;
void gg()const{
cout << "lkq" << endl;
}
};
Investment* creat() {
return new Two;
}
int main() {
auto_ptr<Investment> p(creat());
auto_ptr<Investment>q = p;
}
请记住:
为防止资源泄漏,请使用RAII对象,它们在构造函数中获得资源并在析构函数中释放资源。
两个常被使用的RAII classes分别是tr1::shared_ptr和auto_ptr,前者通常是较佳选择,因为其copy行为比较直观。若选择auto_ptr,复制动作会使它(被指物)指向null。
本文探讨了在C++中如何使用RAII(Resource Acquisition Is Initialization)对象如auto_ptr和shared_ptr来避免内存泄漏的问题。通过具体示例展示了当函数抛出异常或提前返回时,这些对象如何确保资源得到正确释放。
404

被折叠的 条评论
为什么被折叠?



