前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >完成端口IO模型

完成端口IO模型

作者头像
用户1154259
发布2018-01-17 15:05:31
9900
发布2018-01-17 15:05:31
举报

IOCP(IO完成端口)是一种伸缩性的IO模型,广泛应用于各种类型的高性能服务器,如Apache等。

IO完成端口,应用程序使用线程池处理异步IO请求的一种机制。

最初设计:

  应用程序发出一些异步IO请求设备驱动把这些工作项目排序到完成端口,在完成端口上等待线程池便可以处理这些完成IO。

完成端口实际上是一个WINDOWS IO结构,可以接收多种对象的句柄。

                                   1 创建完成端口对象                              

调用CreateIoCompletionPort函数创建一个完成端口对象,winsock使用这个对象为任意数量的套接字句柄管理IO请求

代码语言:javascript
复制
HANDLE CreateIoCompletionPort(
        HANDLE FileHandle, //关联的套接字句柄
        HANDLE ExistingCompletionPort,//创建完成端口的对象句柄
        ULONG_PTR CompletionKey,//指定一个句柄唯一的数据
        DWORD NumberOfConcurrentThreads//同时执行线程数量
    );

此函数作用:1 创建完成端口对象   2 将一个或者多个句柄关联到IO完成端口对象

例子:

代码语言:javascript
复制
HANDLE hCompletion = ::CreateIoCompletionPort(INVALID_HANDLE_VALUE,0,0,0);

                                 2 IO服务器线程和完成端口                      

关联套接字之前,创建一个或者多个工作线程,在完成端口上执行并处理投递到完成端口上的IO请求

                                 3 完成端口和重叠IO                               

在套接字上投递重叠发送和接收请求处理IO。

IO操作完成后,系统向完成端口对象发送一个完成通知封包。

IO完成端口以 先进先出的方式排队

代码语言:javascript
复制
BOOL GetQueuedCompletionStatus(
        HANDLE CompletionPort, //完成端口对象句柄
        LPDWORD lpNumberOfBytes,//取得IO操作期间
        PULONG_PTR lpCompletionKey,
        LPOVERLAPPED* lpOverLapped,
        DWORD dwMilliseconds
    );
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2012-10-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档