使用非阻塞I/O的应用程序也经常使用poll、select和epoll系统调用。Poll 、epoll和select功能本质上是一样的:都允许进程决定是否可以对一个或多个打开的文件做非阻塞的读取或写入。这些调用也会阻塞进程,直到给定的文件描述符集合中的任何一个可读取或写入。因此,常常用于那些要使用多个输入或输出流而又不会阻塞于其中任何一个流的应用程序中。
所有三个系统调用都通过驱动程序的poll方法提供。原型如下:
Unsignedint (*poll)(struct file *filp,poll_table *wait);//当用户空间程序在驱动程序关联的文件描述符上执行poll、select或 epoll系统调用时,该驱动程序方法将会被调用。该设备方法分为两步处理:
1) 在一个或多个可指示poll状态变化的等待队列上调用poll_wait.如果当前没有文件描述符可用来执行I/O,则内核将使进程在传递到该系统调用的所有文件描述符对应的等待队列上等待。
2) 返回一个用来描述操作是否可以立即无阻塞执行的为掩码。
Poll 和select调用的目的是确定接下来的I/O操作是否会阻塞。Poll和select的更重要的用途是他们可以使应用程序同时等待多个数据流。
当用户应用程序调用了poll、select或epoll函数时,内核会调用由该系统调用引用的全部文件的poll方法,并向它们传递同一个poll_table.poll_table结构是构成实际数据结构的一个简单封装。