注意:
- 赋值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; }
原文地址:https://www.cnblogs.com/pfsi/p/9195221.html
时间: 2024-10-04 17:55:40