I/O多路复用
定义:
I/O多路复用是一种同步IO模型,实现一个线程可以监视多个文件句柄;
一旦某个文件句柄就绪,就能够通知应用程序进行相应的读写操作;
没有文件句柄就绪时会阻塞应用程序,交出cpu。
其实简单的理解就是使用单个线程通过记录跟踪每一个流(I/O)的状态来同时管理多个I/O,以此来减少线程的创建和切换的开销,进而提高服务器的吞吐能力。
- 多路是指网络连接
- 复用是指同一个线程(使用一个线程处理 N 个 IO 请求,没有上下文切换和线程的创建和销毁,程序更快)
- 有三种实现方式
1、select
(1) 工作原理
内核调用select传入要监听的文件描述符集合(可读、可写或异常)开始监听,select处于阻塞状态,当有事件发生或设置的等待时间timeout到了就会返回,返回时传出有事件发生的文件描述符集合。但select传出的集合并没有告诉用户集合中包括哪几个就绪的文件描述符,需要用户后续进行遍历操作。
(2) select底层采用数组存储
(3) 优点:
- select的可移植性较好,可以跨平台;
- select可设置的监听时间timeout精度更好,可精确到微秒,而pol