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

注意:

  • 赋值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;
}

猜你喜欢

转载自www.cnblogs.com/pfsi/p/9195221.html
今日推荐