CreateThread函数

函数功能:创建线程

函数原型:

HANDLE WINAPI    CreateThread(

LPSECURITY_ATTRIBUTES    lpThreadAttributes,

SIZE_T    dwStackSize,

LPTHREAD_START_ROUTINE    lpStartAddress,

LPVOIDlp    Parameter,

DWORD    dwCreationFlags,

LPDWORD    lpThreadId

);

函数说明:

第一个参数表示线程内核对象的安全属性,一般传入NULL表示使用默认设置。

第二个参数表示线程栈空间大小。传入0表示使用默认大小(1MB)。

第三个参数表示新线程所执行的线程函数地址,多个线程可以使用同一个函数地址。

第四个参数是传给线程函数的参数。

第五个参数指定额外的标志来控制线程的创建,为0表示线程创建之后立即就可以进行调度,如果为CREATE_SUSPENDED则表示线程创建后暂停运行,这样它就无法调度,直到调用ResumeThread()。

第六个参数将返回线程的ID号,传入NULL表示不需要返回该线程ID号。

函数返回值:

成功返回新线程的句柄,失败返回NULL。

时间: 2024-08-07 00:04:34

CreateThread函数的相关文章

CreateThread函数&&CString::GetBuffer函数

对这个两个常见的windows下的函数学习了一下: //最简单的创建多线程实例 #include <stdio.h> #include <windows.h> //子线程函数 DWORD WINAPI ThreadFun(LPVOID pM) { printf("子线程的线程ID号为:%d\n子线程输出Hello World\n", GetCurrentThreadId()); return 0; } //主函数,所谓主函数其实就是主线程执行的函数. int m

015 _beginthreadex CreateThread 函数区别

_beginthreadex讲解● _beginthreadex ○ 纯 C/C++ API ○ 多线程这一块的运行库 ○ C语言的错误处理机制 errno ○ 3条 ○ 线程变得不安全了 _beginthreadex(); //要比CreateThread 安全尽量使用_beginthreadex(); 创建线程 //分配空间 //调用CreateThread _endthreadex(); CreateThread(); EndThread();

VC++ AfxBeginThread 与 CreateThread 的区别

简言之:AfxBeginThread是MFC的全局函数,是对CreateThread的封装.    CreateThread是Win32 API函数,前者最终要调到后者.具体说来,CreateThread这个 函数是windows提供给用户的 API函数,是SDK的标准形式,在使用的过程中要考虑到进程的同步与互斥的关系,进程间的同步互斥等一系列会导致操作系统死锁的因素,用起来比较繁琐一些,初学的人在用到的时候可能会产生不可预料的错误,建议多使用AfxBeginThread,是编译器对原来的Cre

秒杀多线程第二篇 多线程第一次亲密接触 CreateThread与_beginthreadex本质区别

版权声明:本文为博主原创文章,未经博主允许不得转载. 本文将带领你与多线程作第一次亲密接触,并深入分析CreateThread与_beginthreadex的本质区别,相信阅读本文后你能轻松的使用多线程并能流畅准确的回答CreateThread与_beginthreadex到底有什么区别,在实际的编程中到底应该使用CreateThread还是_beginthreadex? 使用多线程其实是非常容易的,下面这个程序的主线程会创建了一个子线程并等待其运行完毕,子线程就输出它的线程ID号然后输出一句经

秒杀多线程第二篇 多线程第一次亲热接触 CreateThread与_beginthreadex本质差别

本文将带领你与多线程作第一次亲热接触,并深入分析CreateThread与_beginthreadex的本质差别,相信阅读本文后你能轻松的使用多线程并能流畅准确的回答CreateThread与_beginthreadex究竟有什么差别,在实际的编程中究竟应该使用CreateThread还是_beginthreadex? 使用多线程事实上是很easy的,以下这个程序的主线程会创建了一个子线程并等待其执行完成,子线程就输出它的线程ID号然后输出一句经典名言--Hello World.整个程序的代码很

_beginthread 和 CreateThread 区别

/*------------------------------------------------------------------------------------------------- 摘录时间 2017-03-03; _beginthread 和 CreateThread 区别; 程序员对于Windows程序中应该用_beginthread还是CreateThread来创建线程,一直有所争论; 本文将从对CRT源代码出发探讨这个问题; I. 起因; 今天一个朋友问我程序中究竟应该

CreateThread与_beginthreadex本质区别

函数功能:创建线程 函数原型: HANDLEWINAPICreateThread( LPSECURITY_ATTRIBUTESlpThreadAttributes, SIZE_TdwStackSize, LPTHREAD_START_ROUTINElpStartAddress, LPVOIDlpParameter, DWORDdwCreationFlags, LPDWORDlpThreadId ); 函数说明: 第一个参数表示线程内核对象的安全属性,一般传入NULL表示使用默认设置. 第二个参数

(转)CreateThread与_beginthread,内存泄漏为何因(原帖排版有些不好 ,所以我稍微整理下)

在写c++代码时,一直牢记着一句话:决不应该调用CreateThread. 应该使用Visual   C++运行期库函数_beginthreadex.好像CreateThread函数就是老虎,既然这样为什么微软要开发这个函数呢? 不要用 CreateThread 创建线程.并用 CloseHandle 来关闭这个线程,因为这样会导致内存泄露,而应该用 _beginthread 来创建线程,_endthread 来销毁线程.其实,真正的原因并非如此. 因为CreateThread 后,线程终止运行

CreateThread PK _beginthreadex

例子: #include<windows.h>#include<process.h>#include<stdio.h> HANDLE g_hEvent;UINT _stdcall ChildFunc( LPVOID); int main(){ HANDLE hChildThread; UINT uId; //创建一个自动重置的(auto-reset events),未受信的(nosignaled)事件内核对象 g_hEvent=::CreateEvent(NULL,FA