5张图看懂Unix/Linux中的同步IO和异步IO
前言
在Linux系统中,一切皆为文件,任何对设备读写操作都可以认为是对文件句柄的读写操作。在对文件的读写过程中,一般需要用户态和内核态的相互切换,从而有了同步IO和异步IO。从定义上的区别是:同步IO操作导致请求进程阻塞,直到IO操作完成,而异步IO操作不导致请求进程阻塞。接下来,以UDP网络套接字编程中的recvfrom函数为例,了解一下Unix下的5种IO模型(阻塞IO、非阻塞IO、IO多路复用、信号驱动式IO以及异步IO)。
1、同步IO模型
1.1、阻塞IO和非阻塞IO
1.2、IO多路复用和信号驱动式IO
2、异步IO模型
注意:支持POSIX异步IO模型的系统比较罕见,不能确定这样的系统是否支持套接字上的这种模型
总结
一个输入操作主要包括数据准备阶段和数据拷贝阶段。阻塞IO、非阻塞IO、多路复用IO、信号驱动式IO都属于同步IO模型,它们虽然在数据准备阶段处理不同(有阻塞的也有不阻塞的),但在数据拷贝阶段相同,都需要阻塞等待数据拷贝完成,尽管拷贝数据期间的时间消耗是非常短。