条款 13: 以对象管理资源
为防止资源泄漏,请使用 RAII对象,它们在构造函数中获得资源并在析构函数中释放资源。
两个常被使用的RAII classes 分别是 shared_ptr和 auto_ptr 。前者通常是较佳选择,因为其copy 行为比较直观。若选择auto_ptr,复制动作会使它(被复制物)指向 null。
个人理解:保证所有的资源被释放。 RAII:"资源取得时机便是初始化时机"(Resource Acquisition Is Initialization;RAIl)
条款 14: 在资源管理类中小心 copying 行为
复制RAII对象必须一并复制它所管理的资源,所以资源的 copying 行为决定RAII对象的 copying 行为。
普遍而常见的RAII class copying 行为是:抑制 copying 、施行引用计数法(reference counting) 。不过其他行为也都可能被实现。
个人理解:引用计数是在使用共享内存中比较常见的行为。
条款 15: 在资源管理类中提供对原始资源的访问
APls 往往要求访问原始资源( raw resources) ,所以每一个RAII class 应该提供一个"取得其所管理之资源"的办法。
对原始资源的访问可能经由显式转换或隐式转换。一般而言显式转换比较安全,但隐式转换对客户比较方便。
个人理解:不应该直接去拿,而是应该通过接口封装;
条款 16: 成对使用 new 和 delete 时要采取相同形式
如果你在 new 表达式中使用[], 必须在相应的 delete 表达式中也使用[]。如果你在 new 表达式中不使用[], 一定不要在相应的delete 表达式中使用[]。
个人理解:在申请内存是数组的情况下,回收的数据应该也是数组
条款 17: 以独立语句将 newed 对象置入智能指针
以独立语句将 newed 对象存储于(置入)智能指针内。如果不这样做,一旦异常被抛出,有可能导致难以察觉的资源泄漏。
个人理解:C++ 申请的对象,以智能指针的形式管理。 如果不单独去实现的shared_ptr,可能编译器发生优化,导致内存泄漏;