EnterCriticalSection似乎没有被阻止
EnterCriticalSection doesnt seem to be blocking
本文关键字:EnterCriticalSection 更新时间:2023-10-16
我有以下代码来创建线程来完成一些工作(为了清晰起见,已提交部分)。
CRITICAL_SECTION gCS;
class Locker
{
public:
Locker(CRITICAL_SECTION& cs): m_cs(cs)
{
EnterCriticalSection(&m_cs);
}
~Locker()
{
LeaveCriticalSection(&m_cs);
}
private:
CRITICAL_SECTION m_cs;
};
...
HRESULT MyClass::FinalConstruct()
{
InitializeCriticalSection(&gCS);
}
...
DWORD WINAPI MyClass::CreateThread()
{
hWriteReceiptThread = CreateThread(
NULL, // default security attributes
0, // use default stack size
MyClass::RunThread, // thread function name
NULL, // argument to thread function
0, // use default creation flags
&dwThreadId); // returns the thread identifier
return 0;
}
DWORD WINAPI MyClass::RunThread(LPVOID args)
{
{
LogInfo("getting lock for critical Section");
Locker lock(gCS);
EnterCriticalSection(&gCS);
LogInfo("entered Critical Section");
//... do lots of stuff
LogInfo("leaving critical section");
LeaveCriticalSection(&gCS);
LogInfo("left critical section");
}
}
当它运行时,会出现以下打印语句(每个打印语句都会在语句之前打印GetCurrentThreadId()
返回的数字。看起来关键部分没有效果。例如,线程7608得到了锁,然后后面的两个线程也在它完成之前得到了锁。有人能深入了解这是如何发生的吗?
16004 Critical section initialised
7608 getting lock for critical Section
7608 Entered Critical Section
11412 getting lock for critical Section
11412 Entered Critical Section
12860 getting lock for critical Section
6552 getting lock for critical Section
6552 Entered Critical Section
5524 getting lock for critical Section
5524 Entered Critical Section
7608 leaving critical section
7608 left critical section
感谢
根据文档:
无法移动或复制关键截面对象。
您正在复制关键部分并对副本进行操作。
Locker(CRITICAL_SECTION& cs): m_cs(cs)
^^^^^^^^
...
CRITICAL_SECTION m_cs;
您可能想复制参考资料,而不是实际的关键部分。
CRITICAL_SECTION& m_cs;
^ reference