以链接的例子为基础:
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函数的时间。