异步IO、APC、IO完成端口、线程池与高性能服务器(二) APC
来源:互联网 发布:2017网络互助平台 编辑:程序博客网 时间:2024/05/28 04:55
Alertable IO(告警IO)提供了更有效的异步通知形式。ReadFileEx / WriteFileEx在发出IO请求的同时,提供一个回调函数(APC过程),当IO请求完成后,一旦线程进入可告警状态,回调函数将会执行。
以下五个函数能够使线程进入告警状态:
SleepEx
WaitForSingleObjectEx
WaitForMultipleObjectsEx
SignalObjectAndWait
MsgWaitForMultipleObjectsEx
线程进入告警状态时,内核将会检查线程的APC队列,如果队列中有APC,将会按FIFO方式依次执行。如果队列为空,线程将会挂起等待事件对象。以后的某个时刻,一旦APC进入队列,线程将会被唤醒执行APC,同时等待函数返回WAIT_IO_COMPLETION。
QueueUserAPC可以用来人为投递APC,只要目标线程处于告警状态时,APC就能够得到执行。
使用告警IO的主要缺点是发出IO请求的线程也必须是处理结果的线程,如果一个线程退出时还有未完成的IO请求,那么应用程序将永远丢失IO完成通知。然而以后我们将会看到IO完成端口没有这个限制。
下面的代码演示了QueueUserAPC的用法。
/************************************************************************/
/* APC Test. */
/************************************************************************/
DWORD WINAPI WorkThread(PVOID pParam)
{
HANDLE Event = (HANDLE)pParam;
for(;;)
{
DWORD dwRet = WaitForSingleObjectEx(Event, INFINITE, TRUE);
if(dwRet == WAIT_OBJECT_0)
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--)
{
QueueUserAPC(APCProc, hThread, (DWORD)(PVOID)"APC here/n");
if(!bFast)
Sleep(1000);
}
SetEvent(QuitEvent);
WaitForSingleObject(hThread, INFINITE);
CloseHandle(hThread);
}
- 异步IO、APC、IO完成端口、线程池与高性能服务器(二) APC
- 异步IO、APC、IO完成端口、线程池与高性能服务器之二 APC
- 异步IO、APC、IO完成端口、线程池与高性能服务器之二 APC
- 异步IO、APC、IO完成端口、线程池与高性能服务器(一) 异步IO
- (转载)异步IO、APC、IO完成端口、线程池与高性能服务器 (二)
- 异步IO、APC、IO完成端口、线程池与高性能服务器 (二)
- (转载)异步IO、APC、IO完成端口、线程池与高性能服务器 (二)
- 异步IO、APC、IO完成端口、线程池与高性能服务器(四) 线程池
- 异步IO、APC、IO完成端口、线程池与高性能服务器之一 异步IO
- 转载:异步IO、APC、IO完成端口、线程池与高性能服务器之一 异步IO
- 异步IO、APC、IO完成端口、线程池与高性能服务器之一 异步IO
- 异步IO、APC、IO完成端口、线程池与高性能服务器之一 异步IO
- 异步IO、APC、IO完成端口、线程池与高性能服务器之一 异步IO
- 异步IO、APC、IO完成端口、线程池与高性能服务器(三) IO完成端口
- 异步IO、APC、IO完成端口、线程池与高性能服务器之四 线程池
- (转载)异步IO、APC、IO完成端口、线程池与高性能服务器 (五)
- (转载)异步IO、APC、IO完成端口、线程池与高性能服务器 (四)
- (转载)异步IO、APC、IO完成端口、线程池与高性能服务器 (三)
- XMLHTTP 对象及其方法
- 建立项目中的每日构建
- SAP 史上最完整替代与取代资料
- UML中的关系定义
- 异步IO、APC、IO完成端口、线程池与高性能服务器(一) 异步IO
- 异步IO、APC、IO完成端口、线程池与高性能服务器(二) APC
- 异步IO、APC、IO完成端口、线程池与高性能服务器(三) IO完成端口
- 异步IO、APC、IO完成端口、线程池与高性能服务器(四) 线程池
- 异步IO、APC、IO完成端口、线程池与高性能服务器(五) 服务器的性能指标
- I/O Completion Ports
- MOSS 2007
- 水晶报表金额大写函数
- xp远程桌面强制登录命令
- SS/XS增加自定义页面很不方便