epoll和select的区别

select,epol都是linux下的i/o多路复用机制,i/o多路复用就通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。但select,epoll本质上都是同步i/o,因为他们都需要在读写事件就绪后自己负责进行读写,也就是说这个读写过程是阻塞的,而异步i/o则无需自己负责进行读写,异步i/o的实现会负责把数据从内核拷贝到用户空间。

区别:
1.i/o模型不同,select采用轮询模型,每次都要遍历所有的文件描述符集合,epoll是基于时间驱动的模型,通过回调函数处理活跃的文件描述符,效率更高。
2.文件描述符数量限制不同,select限制在1024左右,epoll限制数万个文件描述符,适用于高并发场景
3.事件触发方式不同,epoll支持两种触发模式et(边缘触发),lt(水平触发);select只支持lt;ET模式是指描述符由不可读或者不可写变为可读或者可写时,epoll才通知有事件发生,LT模式则是描述符  只要可读或者可写,epoll就通知有事件发生。
4.内核实现机制不同:select是系统调用,每次调用都要把全部的描述符集合从用户态传输到内核态并且需要判断每个描述符是否就绪;epoll是内核空间和用户空间共享一块内存,只需要在内核空间注册一个时间表,然后等待通知,不需要对已注册的文件描述符进行遍历

你可能感兴趣的:(linux,c++,linux)