Effective C++条款14:小心资源管理类的copy操作

以链接的例子为基础:

class MutexLock{
public:
    explicit MutexLock(pthread_mutex_t *_lock):lock_obj(_lock){
        pthread_mutex_lock(lock_obj);
    }
 
    ~MutexLock(){
        pthread_mutex_unlock(lock_obj);
    }
 
private:
    pthread_mutex_t * const lock_obj;
    //No copying allowed
    MutexLock(const MutexLock&);
    void operator=(const MutexLock&);
};
  • Q:资源管理类能否进行拷贝操作呢?无外乎两种情况
  • 1. 禁止拷贝

 对于MutexLock类来说是不希望进行拷贝的,所以会有禁止拷贝的代码

private://因为是private,所以禁止拷贝。
    pthread_mutex_t * const lock_obj;    
    //No copying allowed
    MutexLock(const MutexLock&);
    void operator=(const MutexLock&);

2.利用引用计数来决定执行 unlock(); shared_ptr当计数为0默认会调用对象的析构函数,对本例的mutex来说,希望是执行unlock();,C++已经为我们提供了自定义的当计数为0执行的操作(参考写法:shared_ptr自定义删除器 Deleter_zion--6135的博客-CSDN博客)
实现起来大概是这样的:
 

#include <iostream>
#include <memory>
#include <mutex>
// #include <pthread.h>
using namespace std;
 
void unlockFunc(mutex *AA);
static mutex *mutex_global;
class Lock {
   public:
    explicit Lock(mutex *pm):mutexPtr(pm, unlockFunc)  //提供unlock函数为删除器
    {
        mutexPtr.get()->lock();
        cout << "lock -- " << mutexPtr <<endl;
    }
 
private:
    std::shared_ptr<mutex> mutexPtr;
};
 
void unlockFunc(mutex *AA) {
        cout << "unlock -- " << AA<< endl;
 
    AA->unlock();
}
 
 
void add(){
    {
        //使用构造函数加锁, deleter函数解锁
        Lock tmp(mutex_global);
    } //出作用域use_cpunt = 0,调用unlockFunc
}
 
 
int main()
{
    add();
    std::cout << "get wait\n";
    std::cin.get();
 
}

总结:(1)如果不希望拷贝操作,可在代码中明确声明

           (2)通过在资源管理类定义share_ptr<mutex>来决定调用deleter函数的时间。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值