more effective c++关于异常这一大节,会有一篇总体的文章(还在一点点的往下写的过程中),以比较简短的语句来描述异常这一大节的每一个小节的精髓,而整个大节会涉及很多测试,每一个测试会有一篇文章,对应着每一个小节。这一篇文章是针对第9节如何利用局部对象管理资源的。
思想:
局部对象管理资源,当中途调用出现异常的时候,利用局部对象的析构函数必须被调用的策略,在析构函数中做释放资源的操作。
一个局部对象存放[必须自动归还的资源],利用对象的析构函数归还资源。auto_ptr, scoped_ptr, auto_lock, FilePtr, HandlePtr 都是这样的思想。
这个是示例代码。
#include <iostream> #include <time.h> #include <memory> using namespace std; /* 作者:lpstudy 日期:2013-3-16 内容:more effective C++异常一章第9节,利用局部对象析构函数释放资源,保证出现异常的时候资源被安全释放。 */ #define TRACE_FUCTION_AND_LINE(fmt, ...) printf("[%20s:%4d]"fmt"\n",__FUNCTION__, __LINE__, ##__VA_ARGS__) //Widget仅仅是一个简单的测试类,作为auto_ptr模板的实例化参数。auto_ptr来管理new的Widget内存,并负责delete class Widget { public: Widget(int nHight = 0): m_nHight(nHight) {TRACE_FUCTION_AND_LINE();} ~Widget(){TRACE_FUCTION_AND_LINE();} void Log () {TRACE_FUCTION_AND_LINE("My Log------%d", m_nHight);} int m_nHight; }; //FilePtr接收一个FILE handle,并负责在对象析构的时候关闭handle。 class FilePtr { public: explicit FilePtr(FILE* f = NULL):m_hFile(f) { TRACE_FUCTION_AND_LINE("m_hFile:%08p", m_hFile); } ~FilePtr() { if (m_hFile) { TRACE_FUCTION_AND_LINE("close m_hFile:%08p", m_hFile); fclose(m_hFile); } } FILE* Get() {return m_hFile;} private: FILE* m_hFile; }; int main() { TRACE_FUCTION_AND_LINE("Trace auto_ptr......."); auto_ptr<Widget> autoWight(new Widget(100)); autoWight->Log(); TRACE_FUCTION_AND_LINE("Trace FilePtr......."); FilePtr filePtr(fopen("data.txt", "a+")); char buf[100] = "Data Test ...\n"; fwrite(buf, 1, strlen(buf), filePtr.Get()); return 0; }
希望还没有获取这种思想,或者知道这种思想但还没有完全领悟的,仔细看看这个简单的例子。
如果想更深入的理解关于auto_ptr以及lock的一些东西,建议看看前面我博客前面介绍的scoped_ptr以及autolock的一些东西。
请相信我,这个非常有价值。google代码大片使用。