APC测试小问题

扬帆886 2009-08-06 04:20:01


DWORD WINAPI WorkThread(PVOID pParam)
{
HANDLE Event = (HANDLE)pParam;
for(;;)
{
DWORD dwRet = WaitForSingleObjectEx(Event, INFINITE, TRUE);
if(dwRet == WAIT_OBJECT_0)
{
printf("event signed");
break;
}

else if(dwRet == WAIT_IO_COMPLETION)
printf("WAIT_IO_COMPLETION\n");
}
return 0;
}

VOID CALLBACK APCProc(DWORD dwParam)
{
printf("%s", (PVOID)dwParam);
}

void TestAPC(BOOL bFast)
{
HANDLE QuitEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
HANDLE hThread = CreateThread(NULL, 0, WorkThread, (PVOID)QuitEvent, 0, NULL);
Sleep(100); // Wait for WorkThread initialized.
for( int i=5; i>0; i--)
{
char a[20]={0};
itoa(i,a,10);
strcat(a,"APC HERE\n");

QueueUserAPC(APCProc, hThread, (DWORD)(PVOID)a);
if(!bFast)
Sleep(1000); /*bFAST = false 投递一个APC,
sleep引起hThread 被调度,执行APC,输出结果1
bFAST =true 5次投递APC,一次hThread被调度
后APC队列中的5个被执行,输出结果2,
我想问的是为 什么不是结果3 */
}
SetEvent(QuitEvent);
WaitForSingleObject(hThread, INFINITE);
CloseHandle(hThread);
}

int main(int argc, char* argv[])
{
TestAPC(true);
//TestAPC(false);
getchar();
return 0;
}

结果1:
5APC HERE
WAIT_IO_COMPLETION
4APC HERE
WAIT_IO_COMPLETION
3APC HERE
WAIT_IO_COMPLETION
2APC HERE
WAIT_IO_COMPLETION
1APC HERE
WAIT_IO_COMPLETION
event signed

结果2:
1APC HERE
1APC HERE
1APC HERE
1APC HERE
1APC HERE
WAIT_IO_COMPLETION
event signed

结果3:
5APC HERE
4APC HERE
3APC HERE
2APC HERE
1APC HERE
WAIT_IO_COMPLETION
event signed
...全文
104 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

64,644

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧