AfxBeginThread()及AfxBeginThread类 使用经验
启动线程的程序举例:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | 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 ; } |
线程服务程序,含有 互斥信号 和 手动方式 结束线程。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | 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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET10 - 预览版1新功能体验(一)