IOCP是什么?

2024-03-23 11:08
文章标签 iocp

本文主要是介绍IOCP是什么?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. IOCP 浅析与实例
众所周知,为了绝对同步,所以很多模式都采用的是同步模式,而不是异步,这样就会产生很大情况下在等待,CPU在切换时间片,从而导致效率比较低。
自从MS在winsocket2中引入了IOCP这个模型之后,他才开始被大家所认知。


IOCP (I/O Completion Port),中文译作IO完成端口,他是一个异步I/O操作的API,他可以高效的将I/O事件通知给我们的应用程序,那游戏项目来说,就是客户端或者服务器。

他与Socket基础API  select()或其他异步方法不同的是,他需要讲一个Socket和一个完成端口绑定在一起,然后就可以进行网路通信了。


2.  什么是同步/异步?

所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。
按照这个定义,其实绝大多数函数都是同步调用(例如sin, isdigit等)。

异步的概念和同步相对。当一个异步过程调用发出后,调用者不能立刻得到结果。
实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者。

逻辑上通俗来讲是完成一件事再去做另外一件事情就是同步,而一起做两件或者两件以上的事情就是异步了。
类似于Win32API中的SendMessage()和PostMessage(),你可以将他理解成单线程和多线程的区别。

3.  什么是阻塞/非阻塞?

阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。
可能阻塞和同步有点类似,但是同步调用的时候线程还是激活的,而阻塞时线程会被挂起。


非阻塞调用和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。


对象的阻塞模式和阻塞函数调用


对象是否处于阻塞模式和函数是不是阻塞调用有很强的相关性,但是并不是一一对应的。阻塞对象上可以有非阻塞的调用方 式,我们可以通过一定的API去轮询状态,在适当的时候调用阻塞函数,就可以避免阻塞。而对于非阻塞对象,调用特殊的函数也可以进入阻塞调用。函数 select就是这样的一个例子。

4.对IOCP的评价如何?

I/O完成端口可能是Win32提供的最复杂的内核对象。 Jeffrey Richter

这是实现高容量网络服务器的最佳方法。Microsoft Corporation

完成端口模型提供了最好的伸缩性。这个模型非常适用来处理数百乃至上千个套接字。Anthony Jones & Jim Ohlund


I/O completion ports特别显得重要,因为它们是唯一适用于高负载服务器[必须同时维护许多连接线路]的一个技术。
Completion ports利用一些线程,帮助平衡由I/O请求所引起的负载。这样的架构特别适合用在SMP系统中产生的”scalable”服务器。 Jim Beveridge & Robert Wiener


5.  IOCP中的完成是指什么意思?

网络通信说白了就是将一堆数据发过来发过去,到底还是数据的操作。
不过大家都知道I/O操作是非常慢的,包括打印机、调制解调器、硬盘等,至少相对于CPU来说是非常慢的。
坐等I/O是很浪费时间的事情,可能你只需要读取100KB的数据,假设读了0.1秒,假设CPU是3.0G Hz,那么CPU已经运行了0.3G次了,
所以CPU这个时候就不满意了,哥这么NB,为什么要等你?


所以我们用另外一个线程来处理I/O操作,使用重叠IO(Overlapped I/O)技术,应用程序可以要求OS为其传输数据,
在完成的时候通知应用程序,然后在进行相应操作,这也就是为什么叫完成的原因。这可以使得应用程序在I/O传输期间可以做其他事情,
这也可以最大限度的利用线程,而让最NB的CPU不至于痴痴等待。


6.    IOCP出现的意义?

写过网络程序的朋友应该很清楚网络程序的原型代码,startup一个WSADATA,
然后建立一个监听socket对象,绑定一个服务器地址,
然后开始监听,无限循环的accept来自客户端的消息,
建立一个线程来处理消息,accept之后线程就被挂起了,知道收到来自客户端的消息。


这样的模型中服务器对每个客户端都会创建一个线程,优点在于等待请求的线程只做很少的事情,大部分时间该线程都在休息,因为recv函数是阻塞的。

所以这样的效率并不是很高,NT小组意识到这样CPU的大部分时间都耗费在线程的上下文切换上,线程并没有抢到cpu时间来处理自己的工作。


NT小组想到了一个解决办法,实现开好N个线程,将用户的消息都投递到一个消息队列中去,然后事先开好的N个线程逐一从消息队列中取出消息并加以处理,
就可以避免为每一个客户端的请求单独开线程,
既减少了线程的资源,也提高了线程的利用率。
所以I/O完成端口的内核对象在NT3.5中首次被引入,MS还是比较伟大的。


这里你也看到了,IOCP其实称作是一种消息处理的机制差不多,而叫完成端口估计也是有历史原因,亦或者是因为他提供了用户与操作系统的一种接口吧。


IOCP百度百科 http://baike.baidu.com/link?url=TlWvNIC9WkRDrxqTD_lh--21gi3JLM5HjmIeB_ozmJgpPoXx-ZXAA6V0MuzGbUrMwk-bCuoRn6UXSNtA6_3HTK
IOCP完成端口的一个简单封装类  http://blog.csdn.net/sky04/article/details/5667190
完成端口IOCP详解  http://blog.csdn.net/beyond_cn/article/details/9336043
IOCP 原理  http://blog.chinaunix.net/uid-11640640-id-2139870.html

这篇关于IOCP是什么?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/838128

相关文章

Windows编程_Lesson004_项目预备_异步IO操作(使用IOCP实现大文件拷贝的项目)

###异步IO机制 异步IO是Windows给我们读写文件提供的的一种的机制,在我们执行CreateFileEx函数是,通过传递相应的参数,就会向操作系统发送请求,那么CreateFileEx函数就会直接返回,它不会等到这个函数操作完成才返回,返回后,这个线程就可以做一些其它的操作,直到收到操作系统完成文件操作的通知,再去处理文件相关的操作,这样不会导致当前的线程发生阻塞;当操作系统收到这个请求时

Go语言直接使用Windows的IOCP API写一个echo服务器

Go的标准库中Windows下的网络是使用了IOCP的,参见go源码go/src/runtime/netpoll_windows.go,标准库为了与Epoll、kqueue等不同平台的IO模式使用统一的API,进行了封装。 如果想直接使用Windows的IOCP API编程,比如想按照:Windows下的高效网络模型IOCP完整示例中的流程写,就需要自行封装IOCP相关的API,虽然标准库中封装

vc 方面的IOCP模型与网络编程 资料

IOCP模型与网络编程  http://blog.csdn.net/neicole/article/details/7549497 百度百科的介绍 http://baike.baidu.com/link?url=T6rQ3AQzgF7lc0rUeziAhZAYuIn7RNDZPBSmuHMs2hW9Y1ygOEIMeAA5_zS3fcMkpM8Tn9qblhBWbM8JXIhiBq

Netty - 五种 I/O 多路复用机制 select、poll、epoll、kqueue、iocp(windows) 对比

文章目录 Preselect、poll、epoll、kqueue、iocp(windows) Pre 高性能网络编程 - select、 poll 、epoll 、libevent select、poll、epoll、kqueue、iocp(windows) 这里我将对比一下常见的多路复用技术:select、poll、epoll、kqueue 和 IOCP(Windo

IOCP以及扩展Windows socket函数应用示例

#include <iostream>#include <winsock2.h>#include <ws2tcpip.h>#include <mswsock.h> //微软扩展的类库using namespace std;#define SEND 0#define RECV 1#define ACCEPT 2#define DATA_LENGTH 1000//单句柄数据定义ty

IOCP Server: Select

客户端代码: /** 文件:Select(客户端)* 说明:项目中需包含 Ws2_32.lib,或使用 #pragma comment(lib, "*.lib")*/#include <stdio.h>#include <WinSock2.h>#define LENGTH 128#define PORT_NUM 8086#define MAX_DELAY 3000 // 比简单示例

[IO复用] Windows IOCP的初步学习

文章目录 前言正文重叠 IO如何理解重叠IO:创建重叠IO重叠IO操作的返回值如何确认IO操作的结果 IOCP比重叠IO多了什么IOCP的流程IOCP和EPOLL的比较 参考 前言 提起IO复用,大部分人首先接触的都是Select、Poll、Epoll,但是在不同的系统中, 往往有不同的高性能IO复用模型,比如Windows中就提供了IOCP(I/O Completion Por

iocp简单例子

首先说明:纯iocp使用的例子看:纯iocp例子(里面的代码可能无法运行,但是下面的代码一定可以运行,可以看看它里面的 PostQueuedCompletionStatus函数 的使用,参考参考然后拿出来放到下面的代码里测试,搞几下就能懂了),主要涉及api:PostQueuedCompletionStatus(它可以触发一次iocp回调,也就是可以手动触发一次iocp回调,可以用来做多线程环境的

Windows下的IOCP模型(二):IOCP使用示例

一 我对IOCP的使用     IOCP以异步处理网络I/O事件、优秀的线程调度等机制,成为Windows环境下性能最优秀的网络通信模型之一。但结合不同的应用场景,IOCP也需要合理的使用方式才能发挥其性能优势。     前段时间需要开发一个Windows环境下的网络通信综合集成系统,作者通过IOCP模型,设计实现了一个用于网络通信的底层模块,这个模块同时支持tcp、udp、广播、udp组播等多

IOCP和SetFileCompletionNotificationModes

在WinSock的IOCP模式中,调用WSASend/WSARecv/WSASendTo/WSARecvFrom等函数发送接受数据。调用WSAxxx函数发送或者接受数据时,如果函数返回了0,表示操作已经立即完成了。但是一般不会在这时进行完成操作的处理,因为Socket已经和完成端口绑定,某个调用GetQueuedCompletionStatus/GetQueuedCompletionStat