AfxBeginThread和AfxEndThread+内存泄露

时间:2022-01-10 17:34:44

ref

http://blog.csdn.net/kut00/article/details/4209680

 

启动线程:

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 对象中有线程的句柄,可以使用该句柄强行杀死线程。但是不推荐使用这种方式,当可以正常结束的时候,选择前两种方法较好。

 

http://hi.baidu.com/reversefish/item/37a07243fdf2da95823ae1af

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函数只能侥幸的保证线程退出,但不能确保。