标签:
首先考虑一个工厂函数
Investment * createInvestment(); void f() { Investment * pInv = createInvestment(); ... delete pInv; }
至少上面这个函数是不安全的,例如如果...里面包含return语句的话,
或者说...里面包含可能会抛出异常的语句。那么就会导致申请的内存得不到释放。
而下面就说明了管理对象的一般方法:
void f() { std::shared_ptr<Investment>(createInvestment()); ... }
用对象来进行管理,这样在离开作用域的时候申请的内存便会自动得到释放。
注意这里包含有两个关键的想法:
1. 获得资源之后应该把他们立刻放到管理对象里面。
2. 管理对象可以利用析构函数使得资源正确的被释放。
注意,shared_ptr等智能指针不能对内置的数组进行管理,因为他们在自己的析构函数里面调用的是
delete而不是delete[], 例如下面这样就是不可取的: shared_ptr<int> spi(new int[1024]); //不要这样做 这种情况应该使用vector来代替: shared_ptr<vector> spi(new vector<int>); //像这样
小结:
1. 为防止资源泄露,应该使用RAII对象,他们在构造函数中获得资源,而在析构函数里面释放资源。
2. auto_ptr不能用在多个指针指向同一个对象的场合。
标签:
原文地址:http://www.cnblogs.com/-wang-cheng/p/4856320.html