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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值