自学Windows多线程知识,例程如下:
#include <iostream>
#include <windows.h>
#include <process.h>
using namespace std;
HANDLE hMutex = NULL;//互斥量
HANDLE mutex = NULL; unsigned WINAPI Fun1(PVOID lpParamter)
{
WaitForSingleObject(mutex, INFINITE);
for (int i = ; i < ; i++)
cout << "A Thread Fun 1 Display!"<<endl;
Sleep();
ReleaseMutex(mutex);
return 0L;
} void main()
{
HANDLE hThread = (HANDLE)_beginthreadex(NULL, , Fun1, NULL, , NULL);//较CreateThread更加安全
//HANDLE hThread = CreateThread(NULL, 0, Fun1, NULL, 0, NULL);
CloseHandle(hThread);
//_endthreadex((unsigned)hThread);//较CloseHandle更加安全
mutex = CreateMutex(NULL,false,"Ohye"); for (int i = ; i < ; i++){
WaitForSingleObject(mutex, INFINITE);
cout << "Main Thread Display!" << endl;
Sleep();
ReleaseMutex(mutex);
} system("pause");
}
运行结果:
_endthreadex与_beginthreadex方法相对应,
1、_endthreadex销毁了在_beginthreadex分配的堆内存(保证了没有内存泄露)。
2、其调用了系统API ExitThread退出线程。
ExitThread VS _endthreadex
在编写C\C++程序时,要调用_endthreadex来结束线程。基于如下两个理由:
1、ExitThread函数非C++函数,线程创建的C++对象不会得到析构。
2、若线程中使用了ptd,ExitThread不会释放内存,造成内存泄露。
CreateThread VS _beginthreadex
一般的理由是,CreateThread有可能照成内存泄露。(如果使用了ptd内存,而CreateThread并不会在内部自动调用释放内存函数,但若链接的是C/C++运行库的dll版本,则其会在线程退出的DLL_THREAD_DETCH通知中释放内存)。