关于 windows 互斥锁CRITICAL_SECTION 多次加锁,需要多少释放的问题

我们程序里,有时某个线程会对锁,连续加两次锁,我以前以为只要释放一次,就会释放该临界区,可不是这样的。应该几次加锁,就应该几次释放锁。

 

CRITICAL_SECTION  mylock;

DWORD WINAPI ThreadFunc3(LPVOID lpParameter)
{
 EnterCriticalSection(&mylock);
  cout << "线程3 第一次加锁成功" << endl;
 EnterCriticalSection(&mylock);
  cout << "线程3 第二次加锁成功" << endl;
 {
  EnterCriticalSection(&mylock);
  cout << "线程3 第二次加锁成功" << endl;
  LeaveCriticalSection(&mylock);
  cout << "线程3 第二次解锁成功" << endl;
 }
  LeaveCriticalSection(&mylock);
  cout << "线程3 第一次解锁成功" << endl;

 return 0;
}

DWORD WINAPI ThreadFunc4(LPVOID lpParameter)
{
 Sleep(1000);
 EnterCriticalSection(&mylock);
 cout << "线程4 加锁成功" << endl;
 LeaveCriticalSection(&mylock);
 return 0;
}

 

在线程3中我们连接两次加了锁,如果我们只释放一次,线程4永远也加不起锁;

只有线程3加了两次锁,也释放了两次,线程4才可加起锁。

故,应该有几次加锁,就应该有几次释放锁。

我想原因可能是这样的,锁里面应该有一个引用计数在里面,在A线程中,对某一锁加锁一次,引用计数加1,对锁解锁一次,引用计数减1,当为0时,才会释放该临界区,线程B才可加上该互斥锁。

你可能感兴趣的:(关于 windows 互斥锁CRITICAL_SECTION 多次加锁,需要多少释放的问题)