栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

以链接的例子为基础:C++资源管理_zion--6135的博客-CSDN博客

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类来说是不希望进行拷贝的,所以会有禁止拷贝的代码

    //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 
#include 
#include 
// #include 
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 < 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 waitn";
    std::cin.get();
 
}

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

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

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/703101.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号