超级好用的C++实用库之互斥锁

2024-05-10 1648阅读

💡 需要该C++实用库源码的大佬们,可扫码关注文章末尾的微信公众号二维码,或搜索微信公众号“希望睿智”。添加关注后,输入消息“超级好用的C++实用库”,即可获得源码的下载链接。

超级好用的C++实用库之互斥锁
(图片来源网络,侵删)

概述

        互斥锁是一种用于多线程编程的同步机制,其主要目的是确保在并发执行环境中,同一时间内只有一个线程能够访问和修改共享资源。互斥锁的最基本功能是防止多个线程同时进入临界区(Critical Section),即一段需要独占执行的代码段。当一个线程获得互斥锁后,其他试图获取该锁的线程将被阻塞,直到拥有锁的线程释放了它。这样可以保证共享数据在任何给定时刻仅由一个线程修改,从而避免数据竞争和不一致的状态。

CHP_Mutex类

        在Windows和Linux操作系统下,实现互斥锁的数据结构和系统API接口有所不同:Windows使用CRITICAL_SECTION,Linux使用pthread_mutex_t。为了实现跨平台的API接口调用,我们封装了CHP_Mutex类。CHP_Mutex类的头文件,可参考下面的示例代码。

#pragma once
#if defined _WIN32
    #include 
    #include 
#else
    #include 
#endif
class CHP_Mutex
{
public:
    CHP_Mutex();
    ~CHP_Mutex();
    void Lock();
    void Unlock();
    bool IsLocked();
private:
#if defined _WIN32
    CRITICAL_SECTION m_cs;
#else
    pthread_mutex_t m_cs;
#endif
};

        CHP_Mutex类的公共接口有3个,下面分别进行介绍。

        Lock:锁定资源。

        Unlock:解锁资源。

        IsLocked:判断是否被锁定。返回值为true表示被锁定,false表示未被锁定。

CHP_Lock类

        直接使用CHP_Mutex类,有时候很容易漏写解锁资源的Unlock函数,从而导致资源一直无法释放。为了解决这个问题,我们可以利用面向对象技术对互斥锁进行封装,确保对象析构时,互斥锁肯定会被释放。基于这些考虑,我们封装了CHP_Lock类。CHP_Lock类的头文件,可参考下面的示例代码。

class CHP_Lock
{
public:
    CHP_Lock(CHP_Mutex &mutex);
    ~CHP_Lock();
private:
    CHP_Mutex &m_mutex;
};

        CHP_Lock类只有一个构造函数和一个析构函数。在构造函数中,可以传入CHP_Mutex类型的互斥锁mutex。在析构函数中,我们会自动释放之前保存的互斥锁。

总结

        在C++ 11中,我们可以通过RAII(Resource Acquisition Is Initialization)技术来安全地管理互斥锁。比如:使用std::lock_guard或std::unique_lock来自动管理互斥锁的生命周期,确保在离开作用域时,无论如何都会释放锁。总之,互斥锁是实现线程同步的关键工具之一,对于保证多线程程序的数据一致性、正确性和安全性至关重要。

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]