lsr*_*wat 8 c c++ winapi multithreading beginthreadex
我正在使用_beginthreadex函数创建一个线程.我传入的函数地址有一个无限的while循环(while(1)).我有threadid和threadhandle.
我可以使用TerminateThread(threadhandle,1);但它很危险.
安全的方法是使用杀死线程,_endthreadex但它只能在线程内部使用,我想从外部杀死线程.
所以请建议是否有一种安全的方法来使用threadid或从外部安全地关闭,结束或杀死线程threadhandle.
mg3*_*0rg 13
你应该 - 从字面上 - 永远不要使用TerminateThread().我甚至不是在开玩笑.如果从外部终止线程,则其中保留的所有资源都将泄露,内部访问的所有状态变量将具有未确定状态,依此类推.
您的问题的解决方案可能是通知您的线程完成自己.它可以通过线程安全手段(参见InterlockedIncrement()),Windows事件或类似的东西改变的volatile变量来完成.如果您的线程有一个消息循环,您甚至可以通过发送消息来要求它停止.
正确的方法是使用CreateEvent创建一个事件"kill me",然后在你希望杀死线程时标记这个事件.而不是让你的线程等待while(1),让它等待while(WaitForSingleObject(hevent_killme, 0)).然后你可以简单地让线程回调完成并返回,不需要调用_endthreadex等.
回调函数示例:
static DWORD WINAPI thread_callback (LPVOID param)
{
...
while(WaitForSingleObject(hevent_killme, 0) != WAIT_OBJECT_0)
{
// do stuff
}
return 0;
}
Run Code Online (Sandbox Code Playgroud)
呼叫者:
HANDLE hevent_killme = CreateEvent(...);
...
void killthread (void)
{
SetEvent(hevent_killme);
WaitForSingleObject(hthread_the_thread, INFINITE);
CloseHandle(hevent_killme);
CloseHandle(hthread_the_thread);
}
Run Code Online (Sandbox Code Playgroud)
永远不要使用TerminateThread.
相反的while(1),你可以使用while(continue_running),在这里continue_running是True当线程循环应该运行.如果要停止线程,请将控制线程设置continue_running为False.当然,请确保continue_running使用互斥锁正确保护,因为它是一个可以从两个线程修改其值的变量.
| 归档时间: |
|
| 查看次数: |
4706 次 |
| 最近记录: |