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