标签:private 对象 shared span color public 编译 函数 ...
注意:
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:在资源管理类中小心拷贝行为
标签:private 对象 shared span color public 编译 函数 ...
原文地址:https://www.cnblogs.com/pfsi/p/9195221.html