_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);