UNIX的5种I/O模型

1)阻塞I/O模型,最流行也是缺省的模型。如下图的例子所示,进程调用recvfrom,这个系统调用一直到数据到达且拷贝到应用缓存区或者是出错时才返回。


2)非阻塞I/O模型。当设置为非阻塞方式时,即通知内核,当请求的I/O操作需要等待时,不让进程睡眠而是返回一个错误。进程收到EWOULDBLOCK,再次调用recvfrom进行轮询。这对CPU时间是极大的浪费,所以这种模型只是偶尔才遇到,一般是特殊的系统中。


3)I/O复用模型。调用select或者poll中的一个上阻塞,而不是阻塞于真正的I/O系统调用,select可以等待多个描述字,其中一个可读,select返回。再调用recvfrom将数据拷贝到应用缓冲区。I/O复用的好处在于,使用select可以等待多个描述字准备好。


4)信号驱动I/O模型。首先通过系统调用sigaction安装一个信号处理程序。此系统调用立即返回,进程继续工作,它是非阻塞的。当数据报准备好时,就生成一个SIGIO信号。我们就可以立即在信号处理程序中调用recvfrom来读数据报。这种模型的好处是当等待数据到达时,可以不阻塞,只是等待信号处理程序的通知。


5)异步I/O模型。调用aio_read函数,给内核传递描述字、缓冲区指针、缓冲区大小、文件偏移,并告诉内核当整个操作完成时如何通知我们。此系统调用立即返回,进程不阻塞于等待I/O操作的完成。



五种 I/O模型的比较,如下图所示。Posix.1的定义:同步I/O操作引起请求进程阻塞,直到I/O操作完成;异步I/O操作不引起请求进程阻塞。根据这个定义前四个模型都属于同步I/O模型,因为真正的I/O操作(recvfrom)阻塞进程,只有;异步I/O模型才与这个异步I/O的定义相符。



你可能感兴趣的:(linux,网络编程)