_beginthreadex是微软的C/C++运行时库函数,CreateThread是操作系统的函数。
_beginthreadex通过调用CreateThread来实现的,但比CreateThread多做了许多工作。
注意:若要创建一个新线程,绝对不要使用CreateThread,而应使用_beginthreadex.
Why?
考虑标准C运行时库的一些变量和函数,如errno,这是一个全局变量。全局变量用于多线程会出什么事,你一定知道的了。故必须存在一种机制,使得每个线程能够引用它自己的errno变量,又不触及另一线程的errno变量.
_beginthreadex就为每个线程分配自己的tiddata内存结构。该结构保存了许多像errno这样的变量和函数的值、地址(自己看去吧)。通过线程局部存储将tiddata与线程联系起来。具体实现在Threadex.c中有。 结束线程使用函数_endthreadex函数,释放掉线程的tiddata数据块。
出处:http://topic.csdn.net/t/20000926/10/31810.html
设置线程名称
void SetThreadName(const char* format, ...) { // This isn't supported on nix? va_list ap; va_start(ap, format); #ifdef WIN32 typedef struct tagTHREADNAME_INFO { DWORD dwType; // must be 0x1000 LPCSTR szName; // pointer to name (in user addr space) DWORD dwThreadID; // thread ID (-1=caller thread) DWORD dwFlags; // reserved for future use, must be zero } THREADNAME_INFO; char thread_name[200]; vsnprintf(thread_name, 200, format, ap); THREADNAME_INFO info; info.dwType = 0x1000; info.dwThreadID = GetCurrentThreadId(); info.dwFlags = 0; info.szName = thread_name; __try { #ifdef _WIN64 RaiseException(0x406D1388, 0, sizeof(info)/sizeof(DWORD), (ULONG_PTR*)&info); #else RaiseException(0x406D1388, 0, sizeof(info)/sizeof(DWORD), (DWORD*)&info); #endif } __except(EXCEPTION_CONTINUE_EXECUTION) { } #endif va_end(ap); }
隐藏dos窗口
#pragma comment( linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"" )重定向标准输出和错误输出( 标准c库的函数,linux下一般不用,直接在bash下重定向io就行了)
freopen(".\\job_calc_similar.log", "a+", stdout); freopen(".\\job_calc_similar.log", "a+", stderr);