首页 > 编程语言 > 详细

effective c++ 条款14:在资源管理类中小心拷贝行为

时间:2018-06-18 15:43:56      阅读:258      评论:0      收藏:0      [点我收藏+]

注意:

  • 赋值RAII对象必须一并复制它所管理的资源,所以资源的拷贝行为决定RAII对象的拷贝行为。
  • 普遍而常见的RAII类拷贝行为是:抑制拷贝,实行引用计数法。
void lock(Mutex* pm);
void unlock(Mutex* pm);

class Lock
{
public:
    explicit Lock(Mutex* pm)
      : mutexPtr(pm)
    { lock(mutexPtr); }
    ~Lock() { unlock(mutexPtr); }
private:
    Mutex* mutexPtr;
};

Mutex m;
...
{
    Lock ml(&m);
    ...
} // 在块末尾,自动解除lock

 

Lock ml1(&m);
Lock ml2(ml1); //将ml1复制到ml2身上,会发生什么?

解决办法
1. 禁止复制,把拷贝操作定义为private。

2. 使用引用记数法。这里可以使用编译器生成的默认析构函数,其会自动调用非静态成员变量(本例中为mutexPtr)的析构函数。mutexPtr的析构函数会在引用计数为0时自动调用tr1::shared_ptr的删除器(本例为unlock)。

class Lock {
public:
    explicit Lock(Mutex* pm)
      : mutexPtr(pm, unlock)
    {
        lock(mutexPtr.get();)
    }
private:
    std::tr1::shared_ptr<Mutex> mutexPtr;
}

 

effective c++ 条款14:在资源管理类中小心拷贝行为

原文:https://www.cnblogs.com/pfsi/p/9195221.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!