笔记:条款13: 以对象管理资源

这是我在阅读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
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 p(creat());
	auto_ptrq = p;
}

请记住:

为防止资源泄漏,请使用RAII对象,它们在构造函数中获得资源并在析构函数中释放资源。

两个常被使用的RAII classes分别是tr1::shared_ptr和auto_ptr,前者通常是较佳选择,因为其copy行为比较直观。若选择auto_ptr,复制动作会使它(被指物)指向null。

你可能感兴趣的:(Effective,C++)