1.利用对象管理资源的思想:类在构造的时候分配资源,在析构的时候释放资源。
void *add(void* args){
sleep(1);
for(int i = 0; i < TASK_CNT; ++i){
//显示加锁, 解锁
pthread_mutex_lock(&lock);
g_num++;
//如果return, break, 则不能释放锁
pthread_mutex_unlock(&lock);
}
pthread_exit(NULL);
}
如下面的add函数注释的部分, //如果return, break, 则不能释放锁,那么写代码需要额外的注意加锁与解锁之间的代码。那么有什么办法可以降低负担呢?
那就是本文正题:利用对象管理资源的思想:创建一个MutexLock类,这个类在构造的时候加锁,在析构的时候解锁。这个类就如下,
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&);
};
在调用的时候,就可以保证只要这个mu_lock的局部变量被销毁的时候就会调用析构函数的解锁函数,不会在其他人维护,修改代码造成额外的问题。并且达到了资源管理的目的。
void *add(void* args){
sleep(1);
for(int i = 0; i < TASK_CNT; ++i){
//使用构造函数加锁, 析构函数解锁
MutexLock mu_lock(&lock);
g_num++;
}
pthread_exit(NULL);
}
- 其实与这个例子类似的还有内存的malloc与free,若通过一个类的构造与析构函数来分配释放内存即可保证局部的资源不会因为意外而导致内存泄漏。当然这种利用对象管理资源是为了优化代码。而在C++中shared_ptr和unique_ptr就是具体的这种思想的实现。