
下面是内存溢出 jb51.cc 通过网络收集整理的代码片段。
内存溢出小编现在分享给大家,也给大家做个参考。
学习windows下多线程的创建使用WINAPI的CreateThread
和C/C++的_beginthread/_beginthreadex
和pthread的pthread_create
win7
mingw
/*purpose: 练习windowAPI的线程函数CreateThread, 和标准C库的线程函数_beginthread/_beginthreadex,和mingw的线程函数pthread_createauthor:[email protected]date:2016/4/20*/#include <windows.h>#include <process.h>#include <iostream>#include <cstdlib>#include <cstdio>#include <pthread.h> //需要-lpthreadusing namespace std;//使用_beginthread创建的线程函数,对线程控制较弱,使用_endthread(voID)结束线程voID __cdecl threadA(voID *p){ for(int i = 0; i < 5; i++) { cout << "thread_A\n"; Sleep(500); }}//使用_beginthreadex创建的线程函数unsigned int __stdcall threadB(voID *p){ for(int i = 0; i < 5; i++) { cout << "thread B\n"; Sleep(500); }}//使用WinAPI的CreateThread创建的线程函数DWORD WINAPI ThreadC(LPVOID param){ for(int i = 0; i < 5; i++) { cout << "thread C\n"; Sleep(300); } return 0;}//使用pthread_create创建的线程函数voID* thread_D(voID *param){ for(int i = 0; i < 5; i++) { cout << "thread D\n"; Sleep(400); } return 0;}int main(int argc,char *argv[]){ _beginthread(&threadA,0); HANDLE hEx = (HANDLE)_beginthreadex(0,&threadB,0); HANDLE hThread = CreateThread(0,ThreadC,0); pthread_t pID; pthread_create(&pID,thread_D,0); WaitForSingleObject(hThread,INFINITE); CloseHandle(hThread); WaitForSingleObject(hEx,INFINITE); CloseHandle(hEx); pthread_join(pID,0); //等待thread_D执行完成 system("pause"); return 0;} name = multi_thread_create$(name): $(name).o g++ -g -o $(name) $(name).o -lpthread -luser32 -lkernel32$(name).o: $(name).cpp g++ -g -c $(name).cpp
make -f makefile.txtcmd以上是内存溢出(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
总结以上是内存溢出为你收集整理的多线程创建小例全部内容,希望文章能够帮你解决多线程创建小例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)