启动线程:

CWinThread* AfxBeginThread( 线程函数, this );

线程的退出:在刚刚使用的时候,退出线程的方法有问题,导致退出的时候异常。

下面说线程退出的方法:

1. 线程函数返回:线程都在死循环中,当满足一定条件时, return ,也会将线程结束。

2.  AfxEndThread:这个函数只能用在线程函数中,当满足一定条件是,调用。

举一个例子:

可以创建一个信号量,用 WaitForSingleObject 函数来检测该信号量的状态。

成员变量 m_hThreadEvent;m_hThreadEvent = CreateEvent( NULL, FALSE, FALSE, NULL ); 

线程的执行函数:

        for ( ; ; )

         {

                   DWORD dwRetVal;

                   dwRetVal = WaitForSingleObject( m_hThreadEvent, 100 );

                   if ( dwRetVal == WAIT_TIMEOUT )

                   {

                            // TODO:

                   }

                   else

                   {

                            DWORD dwExitCode; // stop receive text thread.

                            GetExitCodeThread( m_pThreadRecv->m_hThread, &dwExitCode );

                            AfxEndThread( dwExitCode, TRUE );

                   }

       }

    要结束线程时,使用 SetEvent ,将信号量置为有信号。 该线程是在信号量有信号时,退出。

3. TerminateThread:在 CWinThread 对象中有线程的句柄,可以使用该句柄强行杀死线程。但是不推荐使用这种方式,当可以正常结束的时候,选择前两种方法较好。

 



AfxBeginThread引起的内存泄漏



AfxBeginThread引起的内存泄漏(ZZ)

下面的代码,当用AfxBeginThread开始一个线程时,实际上是有内存泄漏的

for  (ii  =   0 ; ii  <   1000 ; ii ++ ) 

{

  CWinThread  * pWinThread; 

  pWinThread  =  AfxBeginThread(ThreadLBProc, NULL);

  ::Sleep( 500 );

}

UINT ThreadLBProc(LPVOID pParam)

{

   return   0 ;

VC输出的典型提示为:

Detected memory leaks!

Dumping objects ->

thrdcore.cpp(166) : {782} client block at 0x00425300, subtype 0, 112 bytes long.

实际上,只要看到是thrdcore.cpp(166) 的内存泄漏,基本就是同一个原因,和上面的代码一样。

解决方法:

step 1)

在线程函数中,记得写AfxEndThread();(与AfxBeginThread对应,其他的开始线程的函数,有相应的函数)

step 2)

用::WaitForSingleObject()确保线程彻底退出

step 2是比较容易忽略的,用sleep函数只能侥幸的保证线程退出,但不能确保。