前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++多线程-预防死锁

C++多线程-预防死锁

作者头像
cwl_java
发布2020-01-15 10:45:04
7860
发布2020-01-15 10:45:04
举报
文章被收录于专栏:cwl_Java

预防死锁的注意事项: (1)在编写多线程程序之前,首先编写正确的程序,然后再移植到多线程 (2)时刻检查自己写的程序有没有在跳出时忘记释放锁 (3)如果自己的模块可能重复使用一个锁,建议使用嵌套锁 (4)对于某些锁代码,不要临时重新编写,建议使用库里面的锁,或者自己曾经编写的锁 (5)如果某项业务需要获取多个锁,必须保证锁的按某种顺序获取,否则必定死锁 (6)编写简单的测试用例,验证有没有死锁 (7)编写验证死锁的程序,从源头避免死锁

首先,定义基本的数据结构和宏,

代码语言:javascript
复制
typedef struct _LOCK_INFO  
{  
    char lockName[32];  
    HANDLE hLock;  
}LOCK_INFO:  
  
typedef struct _THREAD_LOCK  
{  
    int threadId;  
    LOCK_INFO* pLockInfo[32];  
}THREAD_LOCK;  
  
#define CRITICAL_SECTION_TYPE 1  
#define MUTEX_LOCK_TYPE       2  
#define SEMAPHORE_LOCK_TYPE   3  
#define NORMAL_LOCK_TYPE      4  
  
#define WaitForSingleObject(a, b) \  
        WaitForSingleObject_stub((void*)a, NORMAL_LOCK_TYPE)  
  
#define EnterCriticalSection(a) \  
        WaitForSingleObject_stub((void*)a, CRITICAL_SECTION_TYPE)  
  
#define ReleaseMutex(a) \  
        ReleaseLock_stub((void*)a, MUTEX_LOCK_TYPE))  
  
#define ReleaseSemaphore(a, b, c) \  
        ReleaseLock_stub((void*)a, SEMAPHORE_LOCK_TYPE))  
  
#define LeaveCriticalSection(a) \  
        ReleaseLock_stub((void*)a, CRITICAL_SECTION_TYPE))  

然后,改写锁的申请函数,

代码语言:javascript
复制
void WaitForSingleObject_stub(void* hLock, int type)  
{  
    /* step 1 */  
    WaitForSingleObject(hDbgLock);  
    /* check if lock loops arounds threads */  
    ReleaseMutex(hDbgLock);  
  
    /* step 2 */  
    if(NORMAL_LOCK_TYPE == type)  
        WaitForSingleObject((HANDLE)hLock, INFINITE);  
    else if(CRITICAL_SECTION_TYPE == type)  
        EnterCriticalSection((LPCRITICAL_SECTION)hLock);  
    else  
        assert(0);  
  
    /* step 3 */  
    WaitForSingleObject(hDbgLock);  
    /* add lock to specified threadid list */  
    ReleaseMutex(hDbgLock);  
}  

最后,需要改写锁的释放函数。

代码语言:javascript
复制
void ReleaseLock_stub(void* hLock, int type)  
{  
    /* step 1 */  
    WaitForSingleObject(hDbgLock);  
    /* remove lock from specified threadid list */  
    ReleaseMutex(hDbgLock);  
  
    /* step 2 */  
    if(MUTEX_LOCK_TYPE))== type)  
        ReleaseMutex(HANDLE)hLock);  
    else if(SEMAPHORE_LOCK_TYPE == type)  
        ReleaseSemaphore((HANDLE)hLock, 1, NULL);  
    else if(CRITICAL_SECTION_TYPE == type)  
        LeaveCriticalSection((LPCRITICAL_SECTION)hLock);  
    assert(0);  
}  
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/01/09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档