条款13 以对象管理资源
资源对象最好用指针控制管理。
raw point每次创建后,必须delete掉
std::auto_ptr智能指针,它会自动对所指向的对象调用delete。如果auto_ptr同时指向同一对象,那么delete会被多次调用。
std::shared_ptr引用计数型智慧指针(RCSP),它会在无人指向它时才自动删除该资源。
std::shared_ptr可以指定自定义delete来释放
template <class U> void reset (U* p);
template <class U, class D> void reset (U* p, D del);
template <class U, class D, class Alloc> void reset (U* p, D del, Alloc alloc);
- 为防止资源泄露,请使用RAII对象,它们在构造函数中获得资源并在析构函数中释放资源。
- 两个常被使用的RAII classes分别是tr1::shared_ptr和auto_ptr。前者通常是最佳选择,因为其copy行为比较直观。若选择auto_ptr,复制动作会使它指向null。
条款14 在资源管理类中小心copying行为
资源取得时机便是初始化的时机。
- 复制RAII对象必须一并复制它所管理的资源,所以资源的copying行为决定RAII对象的copy行为。
如果资源被复制不合理,那么应该禁止它。copy函数设置为private
如果希望保有资源直到它最后一个使用者,那么复制RAII对象时,资源应用计数也应该增加。可以用std::shared_ptr
如果资源可以复制任意数量,那么资源管理类复制时,因该是深度拷贝。
如果资源复制需要转移所有权,那么用std::autor_ptr - 普遍而常见的RAII class copying行为是:抑制copying、施行引用计数法。
条款15 在资源管理类中提供对原始资源的访问
- APIs往往要求访问原始资源,所以每个RAII class应该提供共一个“取得其所管理资源”的办法。
- 对原始资源的访问可能经由显式转换或隐式转换。显示比较安全,隐式比较方便。
条款16 成对使用new和delete时要采取相同形式
- 在new表达式中使用[ ],那么delete也要用[ ]。如果new中不用[ ],那么delete中也不用[ ]。
条款17 以独立语句将newed对象置入智能指针
int prioprity();
void processWidget(std::tr1::shared_ptr<Widget> pw, int prioprity);
processWidget(new Widget, priority());
如果priority()中抛出了异常,那么new会无法被释放。最好分开写
std::tr1::shared_ptr<Widget> pw(new Widget);
processWidget(pw, priority());
- 以独立语句将newed对象存储于(置入)只能指针内。如果不这样做,一旦异常被抛出,有可能导致难以察觉的资源泄露。