分享

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

 追逐四叶 2019-06-29
                          标签:  子线程退出  内存泄露  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;
  }                     

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多