select, poll, 和 epoll 都是 Linux 下用于实现 I/O 多路复用的机制。
它们的主要区别在于:
1. 适用平台
select: 可以在多数平台上使用,包括 Windows, Linux, macOS 等。
poll: 可以在多数平台上使用,包括 Linux, macOS 等。但不支持 Windows。
epoll: 仅适用于 Linux 系统。
2. 文件描述符数量限制
select: 受文件描述符数量限制,需要遍历整个文件描述符集合。
poll: 受文件描述符数量限制,需要遍历整个 pollfd 数组。
epoll: 没有文件描述符数量限制,通过回调机制实现高效处理。
3. 事件触发模式
select: 水平触发模式(Level-triggered),即当描述符就绪时会一直通知应用程序进行处理,直到应用程序处理完所有数据后才返回阻塞状态。
poll: 水平触发模式(Level-triggered),与 select 类似。
epoll: 边缘触发模式(Edge-triggered),即只有当描述符状态发生变化时才会通知应用程序进行处理,如果应用程序没有处理完所有数据,则会返回阻塞状态。这种模式可以减少不必要的系统调用,提高性能。
4. 内存占用
select: 需要开辟三个文件描述符集合,且每次调用都需要重新初始化。
poll: 需要开辟一个 pollfd 数组。
epoll: 可以共享内存空间。
总结,epoll 相对于 select 和 poll 具有更高的性能和扩展性,特别是在并发连接数较多时,因为 epoll 采用了异步的方式,而且没有最大连接数的限制。