一个常见的临界区

 
  
class FCriticalSection
{

    CRITICAL_SECTION CriticalSection;

public:
     
    FORCEINLINE FCriticalSection(void)
    {
        InitializeCriticalSection(&CriticalSection);
    }


    FORCEINLINE ~FCriticalSection(void)
    {
        DeleteCriticalSection(&CriticalSection);
    }

    
    FORCEINLINE void Lock(void)
    {
        
        if( TryEnterCriticalSection(&CriticalSection) == 0 )
        {
            EnterCriticalSection(&CriticalSection);
        }
    }

    FORCEINLINE void Unlock(void)
    {
        LeaveCriticalSection(&CriticalSection);
    }
};
 

上面的FCriticalSection封装了windows下面的一个临界区,包括了初始化,销毁,解锁,锁定操作。

在多线程的时候我们会经常出现Lock了但是有没有unlock的情况,以及出现没有成对使用的情况,所有我们实现一个Lock函数来进行lock和unlock,并且保证了lock先于unlock。

class FScopeLock
{

    FCriticalSection* SynchObject;

    FScopeLock(void);

    
    FScopeLock(FScopeLock* InScopeLock);
    FScopeLock& operator=(FScopeLock& InScopeLock) { return *this; }

public:
    FScopeLock(FCriticalSection* InSynchObject) :
        SynchObject(InSynchObject)
    {
        check(SynchObject);
        SynchObject->Lock();
    }

    ~FScopeLock(void)
    {
        check(SynchObject);
        SynchObject->Unlock();
    }
};

FScopeLock 构造函数和析构函数会分别调用临界对象的lock和unlock

这样可以再栈里初始化一个FScopeLock对象。在栈销毁的时候unlock会被自动调并被自动释放。这样保证了整个过程的安全

例子代码如下

{
        FScopeLock ScopeLock( &SynchronizationObject );
}

转载于:https://www.cnblogs.com/littlepearl/archive/2012/05/01/2477874.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值