IO多路复用里select、poll、epoll的区别
来源:互联网 发布:淘宝男士韩版鞋 编辑:程序博客网 时间:2024/06/05 06:19
select
int select (int n, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout);
select 函数监视的文件描述符分3类,分别是writefds、readfds、和exceptfds。调用后select函数会阻塞,直到有描述副就绪(有数据 可读、可写、或者有except),或者超时(timeout指定等待时间,如果立即返回设为null即可),函数返回。当select函数返回后,可以 通过遍历fdset,来找到就绪的描述符。
select目前几乎在所有的平台上支持,其良好跨平台支持也是它的一个优点。select的一 个缺点在于单个进程能够监视的文件描述符的数量存在最大限制,在Linux上一般为1024,可以通过修改宏定义甚至重新编译内核的方式提升这一限制,但 是这样也会造成效率的降低。
poll
int poll (struct pollfd *fds, unsigned int nfds, int timeout);
不同与select使用三个位图来表示三个fdset的方式,poll使用一个 pollfd的指针实现。
struct pollfd { int fd; /* file descriptor */ short events; /* requested events to watch */ short revents; /* returned events witnessed */};
pollfd结构包含了要监视的event和发生的event,不再使用select“参数-值”传递的方式。同时,pollfd并没有最大数量限制(但是数量过大后性能也是会下降)。 和select函数一样,poll返回后,需要轮询pollfd来获取就绪的描述符。
从上面看,select和poll都需要在返回后,通过遍历文件描述符来获取已经就绪的socket。事实上,同时连接的大量客户端在一时刻可能只有很少的处于就绪状态,因此随着监视的描述符数量的增长,其效率也会线性下降。
另外select()和poll()将就绪的文件描述符告诉进程后,如果进程没有对其进行IO操作,那么下次调用select()和poll()的时候将再次报告这些文件描述符,所以它们一般不会丢失就绪的消息,这种方式称为水平触发(Level Triggered)。
epoll
epoll是在2.6内核中提出的,是之前的select和poll的增强版本。相对于select和poll来说,epoll更加灵活,没有描述符限制。
epoll使用一个文件描述符管理多个描述符,将用户关系的文件描述符的事件存放到内核的一个事件表中,这样在用户空间和内核空间的copy只需一次。
epoll可以同时支持水平触发和边缘触发(Edge Triggered,只告诉进程哪些文件描述符刚刚变为就绪状态,它只说一遍,如果我们没有采取行动,那么它将不会再次告知,这种方式称为边缘触发),理论上边缘触发的性能要更高一些,但是代码实现相当复杂。
epoll同样只告知那些就绪的文件描述符(维护用链表实现的等待队列和就绪队列,回调机制将文件描述符正确链接到不同的队列上,最后只需要判断链表是否为空就能清楚是否有事件就绪),而且当我们调用epoll_wait()获得就绪文件描述符时,返回的不是实际的描述符,而是一个代表就绪描述符数量的值,你只需要去epoll指定的一个数组中依次取得相应数量的文件描述符即可,这里也使用了内存映射(mmap)技术,这样便彻底省掉了这些文件描述符在系统调用时复制的开销。
另一个本质的改进在于epoll采用基于事件的就绪通知方式。在select/poll中,进程只有在调用一定的方法后,内核才对所有监视的文件描述符进行扫描,而epoll事先通过epoll_ctl()来注册一个文件描述符,一旦基于某个文件描述符就绪时,内核会采用类似callback的回调机制,迅速激活这个文件描述符,当进程调用epoll_wait()时便得到通知。
总结:
- IO多路复用里select、poll、epoll的区别
- IO多路复用select,poll,epoll的区别
- IO多路复用:select,poll,epoll的区别
- Linux下多路复用IO接口 epoll select poll 的区别
- Linux下多路复用IO接口epoll/select/poll的区别
- 多路复用IO实现方式:select,poll,epoll的区别
- IO多路复用(select poll epoll)
- IO多路复用:select、poll、epoll
- [nginx] Linux下多路复用IO接口 epoll select poll 的区别
- 三种多路复用IO实现方式:select,poll,epoll的区别
- IO多路复用之select poll epoll
- IO多路复用之select、poll以及epoll
- IO多路复用之select、poll、epoll详解
- IO 多路复用之 select、poll、epoll 详解
- IO多路复用:select、poll、epoll示例
- io多路复用之select,poll,epoll总结
- IO多路复用 --select、poll、epoll模式
- IO多路复用之select、poll、epoll详解
- lua C/C++
- [Mark] Spark+Python 初学时遇到的问题
- CUDA编程(三):线程模型
- 笔记11:java_String类的特点
- 23. Merge k Sorted Lists
- IO多路复用里select、poll、epoll的区别
- 大数的运算实现(C++、字符串)、Git使用示例
- 题目1018:统计同成绩学生人数
- Java调用bat文件
- Web前端 - webpack和babel勾结
- 计算机系统和计算的历史
- 日常工作总结(常用命令一)
- bond网卡
- IDEA中创建类似eclipse的项目机构