• 1.自动锁

    #ifndef AUTO_LOCK_H
    #define AUTO_LOCK_H
    
    #include "defines.h"
    
    class AutoLock
    {
    public:
    	AutoLock(HANDLE &mtx) : mutex(mtx)
    	{
    		WaitForSingleObject(mutex, INFINITE);
    	}
    
    	~AutoLock()
    	{
    		ReleaseMutex(mutex);
    	}
    
    private:
    	HANDLE &mutex;
    };
    
    #endif

    2. Mutex Object 

    使用mutex的目的:

            防止不同的线程进入临界区,确保同一时间只有一个线程进入临界区

    mutex作用对象:

            同一进程的多个线程,不同进程的线程


    2.1 Mutex重复持有问题

    总结:

            1.线程A内的代码可以多次申请同一把锁,且每次均可获得

            2.A只有释放相同次数,才可真正解锁。该锁才可被其它线程获得

    综上所述:

    自动锁的使用中下述情况正确:

    void AutoLockInsideFunc()
    {
    	AutoLock lock(mutex);
    	....
    }
    
    void Fxx()
    {
    	AutoLock lock(mutex);
    	AutoLockInsideFunc();
    	....
    }

    一言以蔽之:mutex重复持有没有问题


    2.2 Mutex Object与Critical Section Object区别

    Critical Section Object:适用于同一进程的不同线程间同步。

    Mutex Object:适用于同一进程的不同线程和不同进程的线程间同步。


    2.3 Mutex Object进程同步示例

    创建全局Session命名空间mutex对象

    HANDLE mutex = CreateMutex(NULL,  false, "Global\Mutex");
    
    if(!mutex)
    {
    	printf("CreateMutex == NULL, ErrorCode=%d
    ", GetLastError());
    	return false;
    }
    
    if(GetLastError() == ERROR_ALREADY_EXISTS)
    	printf("Mutex Global\Mutex Already Exist
    ");

    进程A,QQ.exe

    HANDLE h = OpenMutex(MUTEX_ALL_ACCESS, false, "Global\Mutex");
    if(!h)
    {
    	if(GetLastError() == ERROR_FILE_NOT_FOUND)
    		printf("Mutex Global\Mutex Not Exist
    ");
    	else
    		printf("OpenMutex == NULL, ErrorCode=%d
    ", GetLastError());
    	return false;
    }
    
    WaitForSingleObject(h, INFINITE);
    //
    ReleaseMutex(h);
    
    CloseHandle(h);

    进程B,VMSClient.exe

    HANDLE h = OpenMutex(MUTEX_ALL_ACCESS, false, "Global\Mutex");
    if(!h)
    {
    	if(GetLastError() == ERROR_FILE_NOT_FOUND)
    		printf("Mutex Global\Mutex Not Exist
    ");
    	else
    		printf("OpenMutex == NULL, ErrorCode=%d
    ", GetLastError());
    	return false;
    }
    
    WaitForSingleObject(h, INFINITE);
    //
    ReleaseMutex(h);
    
    CloseHandle(h);
    进程退出,系统自动关闭HANDLE当最后一个HANDLE被关闭,Mutex Object会被销毁


    3. 互锁函数

    举例:InterlockedIncrement, InterlockedDecrement, InterlockedAdd, InterlockedDecrement...

    功能:防止多余一条线程同时访问同一个变量,如果变量在共享内存中,不同进程的线程也能使用这种方法。

    注意:InterlockedIncrement参数有时32位long,有时64位long long,而参数类型错问题严重。现统一InterlockedIncrement64。

    标准方式:

    LONG64 l = 0;
    InterlockedIncrement64(&l);


  • 相关阅读:
    人月神话阅读笔记01
    Map Reduce数据清洗及Hive数据库操作
    Hadoop实验六——MapReduce的操作
    假期第九周学习记录
    假期第八周学习记录
    假期第七周学习记录
    hadoop不在sudoers文件中。此事将被报告。 解决方法
    假期第六周学习记录
    2021寒假(22)
    2021寒假(21)
  • 原文地址:https://www.cnblogs.com/chaikefusibushiji/p/6775782.html
Copyright © 2020-2023  润新知