您的位置:首页 > 其它

epoll与select、poll区别和五种I/O模型

2013-10-29 21:23 507 查看
epoll与select、poll区别:

1、epoll不会随着监听fd数目的增加而降低效率,因为它是基于回调的,只关心“活跃”的fd,与fd的数目无关;
而select和poll采用的是轮询的方式处理,每一次都需要遍历全部fd,所以fd的数目越多,它们的效率越低。
2、内核 / 用户空间 内存拷贝问题,如何让内核把 fd消息通知给用户空间呢?在这个问题上select/poll采取了
内存拷贝方法。而epoll采用了共享内存的方式。
3、epoll不仅会告诉应用程序有I/0 事件到来,还会告诉应用程序相关的信息,这些信息是应用程序填充的,
因此根据这些信息应用程序就能直接定位到事件,而不必遍历整个fd集合。

五种I/O模型:
1、阻塞I/O(read/write)
2、非阻塞I/O(如recvfrom,进程会反复调用recvfron)
3、I/O复用(select/poll)
4、信号驱动I/O(发送信号调用信号处理函数)
5、异步I/O:
异步IO使用的不再是read和write的系统接口了,应用工程序调用aio_XXXX系列的内核接口。
当应用程序调用aio_read的时候,内核一方面去取数据报内容返回,另外一方面将程序控制权
还给应用进程,应用进程继续处理其他事务。这样应用进程就是一种非阻塞的状态。
当内核的数据报就绪的时候,是由内核将数据报拷贝到应用进程中,返回给aio_read中定义好的函数处理程序。

各模型如下图:











饮水思源:

C++教程网教学视频

http://www.cnblogs.com/yjf512/archive/2012/05/31/2527966.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  IO模型 epoll poll select