读书笔记Effective C++02[个人向]

1.如果delete object的某个动作被省略过去,泄露的不仅是对象的那一块内存,还包括对象保存的任何资源。为了确保资源总会被释放,我们需要把资源放进对象,当控制流离开这个对象,其析构函数来自动释放那些资源。一种方式是auto_ptr(会使得被复制物指向null)。这种获得资源后立刻放进管理对象的观念被称为RAII:resource aquisition is initialization。更进一步,如果有多个指针指向同一个资源就应当使用引用计数型指针,即智慧指针。由于shared_ptr析构函数的删除动作是delete而不是delete[],因此shared_ptr指向string或者vector时是一个有瑕疵的动作,此时我们要自定义一个lambda表达式。

2.很多时候对RAII对象的复制并不合理,比如对象中含MUTEX,析构函数总使用unlock()时,应该禁止这个对象被复制,因此可以使用前文条款禁止copying行为。

3.有时候我们希望保有资源直到最后一个对象被销毁,可以使用引用计数的方法,而很不幸的是shared_ptr的删除器缺省行为是删除其所指物,这个缺省行为可能并不是那么恰当,因为我们可以是想释放锁定而非删除资源。但是shared_ptr允许指定所谓的删除器,因此可以指定unlock()函数作为删除器,这样就可以释放锁定而不删除资源了。除此之外,如果实在需要这个资源也可以对资源实现深度拷贝,或者像auto_ptr一样彻底转移资源的所有权。

4.尽管智能指针可以通过->或者*来读取资源,但是仍然存在有些应用API希望获得原始指针,而并非shared_ptr。此时智能指针应当提供这样的访问机会(get()函数),但是仍然会有人觉得这样是一种很麻烦的范式而不愿意再使用智能指针(比如说我),从而导致了资源泄露的可能性。上述get()函数的方式是显式转换,还可以有隐式转换的方式:在类中定义一个operator func().

5.成对使用delete和new时,两者的形式要对应起来。否则delete时,难以知道所指的对象是单一对象还是对象数组。调用new时使用[]则调用delete时也要使用[],如果new不使用[],那么delete也不需要使用[]。

6.已独立的语句新建好对象之后,再把这个对象存入智能指针之内,否则笼统的写法譬如func1(shared_ptr<typeA>name(new typeB),func2),此时编译器可能会有预期之外的执行次序的自由,比如执行new->func2(万一崩溃)->shared_ptr。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值