《Effective C++》读书笔记第三章——资源管理(Resource Management)

条款13:以对象管理资源

(Use objects to manage resources)

  • 获得资源后立刻放进管理对象内。 实际上“以对象管理资源”的观念常被称为“资源取得时机便是初始化时机”(Resource Acquisition Is Initialization;RAII)
  • 管理对象运用析构函数确保资源被释放。
  • 两个常被使用的RAII classes分别是tr1::shared_ptr和auto_ptr。前者通常是较佳选择,因为其copy行为比较直观。若选择auto_ptr,复制动作会使它(被复制物)指向null。

条款14:在资源管理类中小心copying行为

(Think carefully about copying behavior in resource-managing classes)

  • 复制RAII对象必须一并复制它所管理的资源,所以资源的copying行为决定RAII对象的copying行为。
  • 普遍而常见的RAII class copying行为是:抑制copying、施行引用计数法。不过其他行为(复制底部资源、转移底部资源的拥有权等)也都可能被实现。

条款15:在资源管理类中提供对原始资源的访问

(Provide access to raw resources in resource-managing classes)

  • APIs往往要求访问原始资源(raw resources),所以每一个RAII class应该提供一个“取得其所管理之资源”的方法。
  • 对原始资源的访问可能经由显示转换或隐式转换。一般而言显示转换比较安全,但隐式转换对客户比较方便。

条款16:成对使用new和delete时要采取相同形式

(Use the same form in corresponding uses of new and delete)

  • 如果你在new表达式中使用[],必须在相应的delete表达式中也使用[]。如果你在new表达式中不使用[],一定不要再相应的delete表达式中使用[]。

条款17:以独立语句将newed对象置入智能指针

(Store newed objects in smart pointers in standalone statements)

  • 以独立语句将newed对象存储于(置入)智能指针内。如果不这样做,一旦异常被抛出,有可能导致难以察觉的资源泄漏。
  • 例如:
    processWidget(std::tr1::shared_ptr< Widget >(new Widget), priority());
    该语句将执行三件事:
    1. 调用priority
    2. 执行"new Widget"
    3. 调用tr1::shared_ptr构造函数
    而执行次序由编译器决定,如果1.在2.和3.中间被执行,并且其发生异常,那么"new Widget"返回的指针将会遗失,从而可能引发资源泄漏。因此,我们应当拆分其为两个语句:
    std::tr1::shared_ptr< Widget > pw(new Widget); // 1.
    processWidget(pw, priority()); // 2.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值