1.区分堵塞、非堵塞
在一个IO操作过程中,以read为例,会涉及到两个过程:
1.等待数据准备好;
2.将数据从内核拷贝到进程中
这两个阶段是否发生阻塞,将产生不同的效果。
堵塞IO:
进程在请求read阻塞io的数据时,操作需要彻底完成后才返回到用户空间
非堵塞IO:
进程在步骤1不堵塞,如果数据没准备好,read(io操作)函数会立即返回一个状态值反馈给进程,所以对于非阻塞io,可以用一个while循环嵌套read来保证数据被读取。
2.区分同步、异步
同步IO
举个例子,同步IO在执行read函数时,如果有数据可读,进程会等待read函数执行完毕后继续执行接下去的代码。从这个层次来,阻塞IO、非阻塞IO操作、IO多路复用都是同步IO。
异步IO
异步IO操作不会导致请求的进程被blocked。当发出read请求,直接返回,等待read完成后,再通过返回值通知调用进程。
3.IO复用的定义及作用
I/O多路复用是通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。常见的IO复用模型有select、poll、epoll三种,IO复用是一种同步IO。</