我试图通过使用互斥锁来保护一段代码。由于代码崩溃,我在下面创建了一个简单的测试代码,它也是如此。崩溃不一定每次都在同一行代码上,而是始终围绕“WaitForSingleObject”或“Sleep”调用。
任何帮助都将不胜感激。
#include <thread>
#include <windows.h>
#include <process.h>
static HANDLE myMutex;
//The function we want to make the thread run.
void task1()
{
WaitForSingleObject(myMutex, INFINITE);
for (int i = 0; i < 20; i++)
{
Sleep(500);
}
ReleaseMutex(myMutex);
}
void task2()
{
Sleep(10);
WaitForSingleObject(myMutex, INFINITE);
for (int i = 0; i < 20; i++)
{
Sleep(10);
}
ReleaseMutex(myMutex);
}
int main(int argc, char **argv)
{
myMutex = CreateMutex(0, FALSE, 0);
std::thread t1(task1);
std::thread t2(task2);
}
答案 0 :(得分:4)
问题是,在main
方法退出之前,您没有等待线程退出。在没有线程退出的情况下调用thread
对象上的析构函数。您需要致电join
以使主方法等待。尝试:
int main(int argc, char **argv)
{
myMutex = CreateMutex(0, FALSE, 0);
std::thread t1(task1);
std::thread t2(task2);
if(t1.joinable())
t1.join();
if(t2.joinable())
t2.join();
}
销毁线程对象。如果*仍然有一个关联的运行线程(即joinable()== true),则调用std :: terminate()。