select 异步阻塞设计,具有良好的跨平台支持。原理
发送io后即返回,当内核文件加载好后,通过socket
发送消息提醒用户线程任务可以继续执行,单个IO速度并没有改善,但是配合多线程使用,可以同时进行多个IO任务
但是其具有一个缺点,select在单个进程中能够监听的文件描述符的数量存在最大限制,在linux上为1024,对于socket进行扫描时是依次扫描,效率低,浪费cpu时间。
epoll的优点:
并没有最大连接限制,没有监听上限,效率提升不是轮询的方式,只有活跃的FD才会调用callback函数
两种工作模式:
LT模式:当epoll检测到描述符事件发生并将此事件通知应用程序,应用程序可以不立即处理该事件。下次调用epoll时,会再次响应应用程序并通知此事件。
ET模式:当epoll检测到描述符事件发生并将此事件通知应用程序,应用程序必须立即处理该事件。如果不处理,下次调用epoll时,不会再次响应应用程序并通知此事件。