zoukankan      html  css  js  c++  java
  • poll和select

    都允许进程决定是否可以对一个或者多个打开的文件做非阻塞的读取或写入。这些调用也会阻塞进程,直到给定的文件描述符集合中的任何一个可读取或写入。常常用于那些要使用多个输入或输出流而又不会阻塞与其中任意一个流的应用程序。

    unsigned int (*poll)(struct file *filp,poll_table *wait);

    当用户程序使用在驱动程序相关联的文件描述符上执行poll,select,或者epoll系统调用时,该驱动程序方法调用。

    分两步:

    1.在一个或者多个可指示poll状态变化的等待队列上调用poll_wait。如果当前没有文件描述符可以用来执行IO,则内核将使进程在传递到该系统调用的所有文件描述符对应的等待队列上等待。

    2.返回一个用来描述操作是否可以立即无阻塞执行的位掩码。

    这些都依赖于驱动程序提供的信息,必须为每一个驱动程序分别实现对应操作。传递给poll方法的第二个参数,poll_table结构,用于在内核中实现poll、select以及epoll调用。它在<linux/poll.h>中声明,驱动程序源代码必须包含这个头文件。驱动程序编写者不需要了解改结构的细节,且需要将其当成一个不透明对象使用。它被传递给驱动程序方法,以使每个可以唤醒进程和修改poll操作状态的等待队列都可以被驱动程序装载。通过poll_wait函数,驱动程序向poll_table结构添加一个等待队列:

    void poll_wait(struct file *,wait_queue_head_t *,poll_table *);

    poll方法执行的第二项任务是返回描述那个操作可以理解执行的位掩码,这也很直接,例如,如果设备已有数据就绪,一个read操作可以立刻完成而不用休眠,那么poll方法应该指出这种情况。几个标志(在<linux/poll.h>asm/poll.h)用来指明可能的操作。

  • 相关阅读:
    code3728 联合权值
    Codevs 4600 [NOI2015]程序自动分析
    code1540 银河英雄传说
    code1074 食物链
    堆排序
    哈夫曼树与哈夫曼码
    优先队列用法
    code1154 能量项链
    code1225 八数码Bfs
    javascript5
  • 原文地址:https://www.cnblogs.com/flintlovesam/p/5138066.html
Copyright © 2011-2022 走看看