Unix I/O 模型
Unix I/O 模型
Unix 可用的 I/O 模型有以下5种:
1.阻塞式 I/O
2.非阻塞式 I/O
3.I/O 复用(select 和 poll)
4.信号驱动式 I/O
5.异步 I/O
前四种又称作 同步 I/O 操作,因为它们会导致进程阻塞,直到 I/O 操作完成。
接下来将会用 UDP 的 recvfrom 函数(因为这个函数比较的简单)来简单介绍以下这5种 I/O 模型。
阻塞式 I/O(block I/O)
阻塞式 I/O 可以说是最常用的 I/O 模型了。在默认情况下所有的套接字都是阻塞的。
当用户进程调用了 recvfrom 函数后(实质上是一个系统调用),控制权由用户进程转接给内核。内核准备好数据报
并将数据从内核复制到用户进程空间
后,再将控制权转接给用户进程。可以说在调用 recvfrom 开始到它返回的整段时间内,用户进程都是被阻塞的。
非阻塞式 I/O(nonblocking I/O)
如果将 recvfrom 设置为非阻塞的,在调用它时会遇到以下两种情况:
1.内核已经准备好数据报了。
2.内核还未准备好数据报。
在第一种情况下,控制权由用户进程转接给内核,内核将数据从内核复制到用户进程空间
后将控制权返回。
在第二种情况下,内核立即返回一个 EWOULDBLOCK 错误,表示内核还未准备好数据报。用户