MFC控制子线程退出的基本思路比较

来源:互联网 发布:mac ctrl c 编辑:程序博客网 时间:2024/06/10 08:38
标签:  子线程退出  内存泄露  2013-02-25 10:45
    要实现主线程控制子线程退出,需要考虑到子线程的响应速度和用户堆内存的泄露问题。一般来说,子线程的主体部分是一个while(1)循环。
    最简单也是最直观的办法是采用全局变量,如在主对话框类头文件中定义一个static BOOL g_ExitThread;子线程程序主体改写为while(g_ExitThread);然后在该循环之外做好收尾工作(释放堆内存)。但是,这种程序结构存在一定的隐患,比如在子线程中使用了sleep函数时,主线程中即便是将g_ExitThread设为FALSE,子线程也必须要等待sleep函数定时时间到才能退出。
    比较简单和可靠的方式是在while(1)循环中使用WaitForSingleObject函数等待信号量。具体原理过于简单,这里就不再复述了,直接看其典型用法即可:
DWORD dw = WaitForSingleObject(p_Dlg->h_ExitEvent, 10000); //等待一个进程结束
  switch (dw)
  {
  case WAIT_OBJECT_0:
   // 在等待超时之前信号量置位
   strtemp = "信号量置位,子线程退出\r\n";
   p_Dlg->m_ctrEdit.SetSel(-1, -1);
   p_Dlg->m_ctrEdit.ReplaceSel(strtemp);
   p_Dlg->SendMessage(WM_THREADMESSAGE,0,0);
   return 0;
   break;
  case WAIT_TIMEOUT:
   // 等待超时  
   strtemp=tm.Format("[%Y年%m月%d日 %X]信号量无效,子线程等待超时\r\n");
   p_Dlg->m_ctrEdit.SetSel(-1, -1);
   p_Dlg->m_ctrEdit.ReplaceSel(strtemp);
   p_Dlg->SendMessage(WM_THREADMESSAGE,0,0);
   break;
  case WAIT_FAILED:
   // 传入的信号量句柄无效
   strtemp = "传入信号量句柄无效\r\n";
   p_Dlg->m_ctrEdit.SetSel(-1, -1);
   p_Dlg->m_ctrEdit.ReplaceSel(strtemp);
   p_Dlg->SendMessage(WM_THREADMESSAGE,0,0);
   return 0;
   break;
  }
原创粉丝点击