"If a thread calls LeaveCriticalSection when it does not have ownership of the specified critical section object, an error occurs that may cause another thread using EnterCriticalSection to wait indefinitely."
关于这个问题我的思考
我认为windows之所以说如果一个线程释放不属于自己的临界区,可能导致其它线程调用该临界区无法进入,永远等待。这种情况发生在释放临界区的线程优先于进入临界区的线程执行,如线程2释放临界区A,临界区的计数变为-1,此时线程1进入临界区A挂起等待,永远得不到执行出现错误。如果能保证线程1在线程2之前执行,则不会出现错误。
我实现的windows下的读写锁操作
void rLock()
{
InterlockedIncrement(&Counter);
if (Counter == 1)
{
EnterCriticalSection(&wcs);
}
}
void runLock()
{
InterlockedDecrement(&Counter);
if(Counter == 0)
{
LeaveCriticalSection(&wcs);
}
}
void wLock()
{
EnterCriticalSection(&wcs);
}
void wunLock()
{
LeaveCriticalSection(&wcs);
}
对使用CRITICAL_SECTION实现读写锁的质疑
最新推荐文章于 2021-12-26 16:29:15 发布
附:MSDN相关描述: