CreateThread()函數介紹:
HANDLE CreateThread(
LPSECURITY_ATTRIBUTES lpThreadAttributes, //指向SECURITY_ATTRIBUTES的指針,NULL默認爲安全,不可被子線程繼承
DWORD dwStackSize, //設置初始棧的大小,以字節爲單位,0表示默認使用與調用該函數的線程相同的空間,任何情況下windows會根據需要自動延伸空間
LPTHREAD_START_ROUTINE lpStartAddress, //指向線程函數的指針。函數定義格式:1、必須爲DWORD WINAPI 函數名 (LPVOID lpParam),格式不正確將無法調用
//2、 直接調用基本類型,但lpStartAddress要這樣通過LPTHREAD_START_ROUTINE轉換——如:(LPTHREAD_S TART_ROUTINE)MyVoid。void myVoid(){return ;}
LPVOID lpParameter,//向線程函數傳遞的參數,是一個指向結構的指針,不需要時爲NULL
DWORD dwCreationFlags, //線程標誌,可取值如下——
//(1)create_suspended(0x00000004):創建一個掛起的線程。
//(2)0:表示創建後立即激活。
//(3)STACK_SIZE_PARAM_IS_A_RESERVATION(0x00010000):dwStackSize參數指定初始的保留堆棧的大小, 否則,dwStackSize指定提交的大小。該標記值在Windows 2000/NT and Windows Me/98/95上不支持。
LPDWORD lpThreadId//保存新線程的ID
);
程序:
#include <iostream>
#include <windows.h>
using namespace std;
DWORD WINAPI ThreadFunc( LPVOID n)
{
cout<<"n="<<n<<endl;
return 0;
}
int myVoid()
{
cout<<"1"<<endl ;
return 0;
}
int main()
{
HANDLE hThread1;
HANDLE hThread2;
DWORD ThreadID;
int i;
for( i = 0; i < 5; ++ i )
{
hThread1 = CreateThread( NULL,0,ThreadFunc, ( LPVOID ) i, 0,&ThreadID );
hThread2 = CreateThread( NULL,0,(LPTHREAD_START_ROUTINE)myVoid, ( LPVOID ) i, 0,&ThreadID );
if( hThread1 )
{
cout<<"Thread lauched "<< i <<endl;
CloseHandle( hThread1);
CloseHandle(hThread2);
}
}
Sleep(2000);
getchar();
return 0;
}
結果簡單分析:
該程序循環創建了5個 hThread1 、hThread2 的線程,每次創建運行完後將子線程關閉,主線程一直運行