VC创建线程

  我们经常会遇到要建立多个线程,以此方便于我们可以同时执行多个事件。这也是我们在VC开发中的一项基础,虽然我曾多次用到,但也会常常忘记。这次记下来,作为一个笔记,为大家学习提供方便。在VC中,无非是创建线程和写线程函数.

一、常规方法:纯使用Platform SDKAPI. 
1, 创建线程: 
#include <windows.h> 
在MFC中通常在OnInitDialog()下面创建线程 
//定义参数:SerialControl 
//------------------变量函数初始化调用区域-------- 
CSerialControl * m_SerialControl=new CSerialControl(); 
m_SerialControl->Create(NULL,"aa",WS_CHILD,CRect(0,0,0,0),this,2,NULL); 
m_SerialControl->InitAllSerialPort(); 
//------------------------------------------------ 
HANDLE hThread1=CreateThread(NULL,0,DetectCar,(LPVOID)SerialControl,0,NULL); 
CloseHandle(hThread1);//此处关闭线程的句柄,但不意味关闭线程,线程在程序退出时关闭 
参数说明: 
HANDLE CreateThread( 
LPSECURITY_ATTRIBUTES lpThreadAttributes,//必须为NULL 
DWORD dwStackSize, //一般为0 ,表示堆栈与外部大小相同 
LPTHREAD_START_ROUTINE lpStartAddress, //线程函数名称 
LPVOID lpParameter, //传递给线程函数的参数,如果为多个,自定义结构体 
DWORD dwCreationFlags, //0表示创建线程后立即启动线程,如果不是立即启动需要调用ResumeThread函数 
LPDWORD lpThreadId);//用来标记该线程的名称 
2, 定义线程函数: 
//函数的定义 
static       DWORD WINAPI DetectCar(LPVOID lpParameter); //一般用静态函数 
//remark:由于线程函数是静态函数,如果要在函数中用到对象,必须通过 
//函数的实现 
/*************************************************** 
*作者:万田 
*时间:2007-13-03 
*函数:DetectCar() 说明:检测线程 
****************************************************/ 
DWORD WINAPI CISSDlg::DetectCar(LPVOID lpParameter) 

       TRACE("Thread DetectCar is running/r/n"); 
       CSerialControl* SControl=(CSerialControl*)lpParameter; 
       //define:record which road is car 
       int Carexit=0; 
       while (TRUE)//do this forever 
       { 
              //get:which road exit car 
              Carexit=SControl->m_GroudDetector1.CarExists(); 
              *********** 
       }

方法二:使用MFC全局函数

CWinThread* AfxBeginThread(( AFX_THREADPROC pfnThreadProc, LPVOID pParam, int nPriority = THREAD_PRIORITY_NORMAL, UINT nStackSize = 0, DWORD dwCreateFlags = 0, LPSECURITY_ATTRIBUTES lpSecurityAttrs = NULL );

这个需要自定义 pfnThreadProc():UINT MyControllingFunction( LPVOID pParam ); 
及传递参数类型。。。。如果创建的是挂起线程,使用CWinThread->ResumeThread 执行

方法三:使用MFC全局函数 
CWinThread* AfxBeginThread( CRuntimeClass* pThreadClass, int nPriority = THREAD_PRIORITY_NORMAL, UINT nStackSize = 0, DWORD dwCreateFlags = 0, LPSECURITY_ATTRIBUTES lpSecurityAttrs = NULL ); 
这里需要从CWinThread 类中派生自己的线程类CMyWinThread , 
CRuntimeClass *rc=RUNTIME_CLASS(CMyWinThread)....利用返回CWinThread 对象的指针就可以对线程进行各种操作。

方法四:使用自己的线程类,并在堆中创建线程对象 
class CMyWinThread : public CWinThread{...},要在派生类中实现自己的虚函数 run().... 
CMyWinThread *mth = new CMyWinThread() 
mth->Create(....)    mth->ResumeThread()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值