/*
该程序演示了通过PeekMessage强制创建消息队列,然后Sleep等待执行创建的线程
*/
#include<windows.h>
#include<tchar.h>
#include<strsafe.h>
#define GRS_USEPRINTF() TCHAR pBuf[1024]={}
#define GRS_PRINTF(...)\
StringCchPrintf(pBuf, 1024, __VA_ARGS__); \
WriteConsole(GetStdHandle(STD_OUTPUT_HANDLE), pBuf, lstrlen(pBuf), NULL, NULL);
DWORD WINAPI ThreadFunction(LPVOID lpParam)
{
//线程函数
GRS_USEPRINTF();
MSG msg = {};
//这句将强制系统创建一个消息队列,注释时候可能看到该线程没有受到任何消息
PeekMessage(&msg,NULL,0,0,PM_NOREMOVE);
//模拟一个耗时的初始化过程
for (int i = 0; i < 10000000; i++);
//一个简单的消息循环
while (GetMessage(&msg, NULL, 0, 0))
{
GRS_PRINTF(_T("线程[ID:0x%x]收到消息-0x%04x\t时间(GetTickCount值)-%u\n"),
GetCurrentThreadId(),msg.message,msg.time);
}
//执行到这里表示收到的是WM_QUIT消息
GRS_PRINTF(_T("线程[ID:0x%x]收到退出消息-0x%04x\t时间(GetTickCount值)-%u\n"),
GetCurrentThreadId(), msg.message, msg.time);
return msg.wParam;
}
int _tmain()
{
DWORD dwThreadID = 0;
HANDLE hThread = CreateThread(NULL,0,ThreadFunction,NULL,0,&dwThreadID);
//这两个消息可能收不到,因为新线程默认没有消息队列
PostThreadMessage(dwThreadID,0x001,0,0);
PostThreadMessage(dwThreadID, 0x002, 0, 0);
Sleep(10);
//强制切换到新线程去执行,住时候有可能看到两个线程都在等待而死锁
PostThreadMessage(dwThreadID, 0x003, 0, 0);
PostThreadMessage(dwThreadID, 0x004, 0, 0);
//向新线程发送退出消息
PostThreadMessage(dwThreadID, WM_QUIT, (WPARAM)GetCurrentThreadId(), 0);
//等待新线程退出
WaitForSingleObject(hThread,INFINITE);
_tsystem(_T("PAUSE"));
return 0;
}