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

posted @   辛河  阅读(831)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示