启动线程的程序举例:
BOOL Cscom::ReadCommTHreadStart(void)//用于 线程启动 { static int thread_n =0; this->threadRunning = false;// 在线程程序中,作为while循环条件。false时,退出线程。 Sleep(10);//等10ms,线程程序退出。 if(this->m_pThread==NULL) { this->m_pThread = AfxBeginThread(comRxThread, (LPVOID)this, THREAD_PRIORITY_NORMAL);// 启动线程运行 this->m_pThread->m_bAutoDelete = FALSE;// 手动推出中断 } if(NULL == m_pThread) { DWORD k=GetLastError(); TRACE("创建新的线程出错!错误号:%d\n",k); return false; } thread_n++; printf("启动线程次数:%d ID号:%x",thread_n,this->m_pThread->m_nThreadID); return true; }
线程服务程序,含有 互斥信号 和 手动方式 结束线程。
UINT __cdecl comRxThread(LPVOID param)// 输入参数用来传递类指针,线程处理函数。 作为 Cscom类友元函数方式定义。 { Cscom* p_Cscom =(Cscom*)param; p_Cscom->threadRunning = TRUE; BYTE* lpBuffer; DWORD nRead; bool bcomFlag; lpBuffer = p_Cscom->m_RecvBuf;// 数据缓冲区首地址 初始化lpBuffer p_Cscom->m_RecvBufLen=0;// 记录缓冲区内 接收字节数清零 WaitForSingleObject(p_Cscom->hmutex,INFINITE); // 等待互斥对象 while(( p_Cscom->ReadCommThread(lpBuffer,&nRead) )// 读取数据帧 &&p_Cscom->threadRunning)// 外部控制线程结束 { //////// 线程退出 语句 p_Cscom->threadRunning =FALSE; ReleaseMutex(p_Cscom->hmutex);// 放弃互斥对象 /////// 线程挂起 语句 ReleaseMutex(p_Cscom->hmutex);// 放弃互斥对象 p_Cscom->m_pThread->SuspendThread(); // 暂停线程 }; ///////// 因使用挂起线程,因此手动方式,退出线程。 否者内存泄露 p_Cscom->m_pThread->ExitInstance();// 退出线程实例 DWORD dwExitCode; dwExitCode =0; do { dwExitCode =0; p_Cscom->threadRunning = false;// 退出线程 CloseHandle( p_Cscom->m_pThread->m_hThread);// 关闭句柄 GetExitCodeThread(p_Cscom->m_pThread->m_hThread,&dwExitCode); }while(STILL_ACTIVE ==dwExitCode ); p_Cscom->m_pThread =NULL; p_Cscom =NULL; return 0; };
功能程序 使用 线程的结果 线程通过suspend 停止,释放互斥信号。 主程序 通过互斥信号 得到thread的结果,通过 resume 启动线程。
Cscom m_Cscom;// 类声明 ////........... m_Cscom.hmutex = CreateMutex(NULL,FALSE,NULL);// 创建一个不是当前线程拥有的(FALSE)互斥对象,用来读写共享数据组 ////...........启动线程 while(!m_Cscom.ReadCommTHreadStart()){};// 开线程,接收数据 while(bround) { if(!m_Cscom.threadRunning) break;//如果线程已经退出,跳出while循环 ////........... Sleep(10);// 间隔性查收数据 WaitForSingleObject(m_Cscom.hmutex,INFINITE); // 等待互斥对象,得到m_RecvBuf[]的读写权 ////...........退出线程服务程序 m_Cscom.threadRunning = FALSE;// 接收到一个完成的信息 m_Cscom.m_pThread->ResumeThread();//恢复线程,终止线程 ////...........恢复线程服务程序 m_Cscom.threadRunning = TRUE; m_Cscom.m_pThread->ResumeThread();//没有完整的报文,恢复线程,继续接收数据
C++ VS2012 内存泄露检测
https://blog.csdn.net/mfcing/article/details/42673393
CWinThread内存释放问题(VC++6.0)
https://blog.csdn.net/zhyuanshan/article/details/1618523
CWinThread类,使用后要不要使用CloseHandle释放内核
https://blog.csdn.net/konglongdanfo1/article/details/78681868?spm=1001.2101.3001.6661.1&utm_medium=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-78681868-blog-1618523.pc_relevant_multi_platform_whitelistv1_exp2&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-78681868-blog-1618523.pc_relevant_multi_platform_whitelistv1_exp2&utm_relevant_index=1