Linux中实现对输入的异步

1:传统的输入信号

传统的输入都是通过阻塞来实现,例如getchar一直等待用户输入。又或者是再curses库中的getch都是通过阻塞的方式来等待用户输入。那么想象一个场景要设计一个游戏,这个游戏可以让玩家动态输入一些值来动态调整游戏参数。不可能通过getchar这样的阻塞函数来获取用户输入把。那么这个该如何实现呢,再想象一下另外一种场景操作系统的CPU不可能是一直等待网卡的输入把。所以对于一些特别的场景阻塞输入是无法满足要求的。下面的这个例子就是一个阻塞输入的例子。

#include<stdio.h>

#include<stdlib.h>

#include<curses.h>

 

void init_setup (  );

void init_end (  );

void on_input (  );

void do_main (  );

int main ( int argc, char *argv[] )

{

 

        init_setup();

        on_input();

        do_main();

        init_end();

        return EXIT_SUCCESS;

}

        /* ----------  end of function main  ---------- */

 

 

 

void init_setup (  )

{

        initscr();

        crmode();

        noecho();

        clear();

}              /* -----  end of function init_setup  ----- */

 

void init_end (  )

{

        endwin();

}              /* -----  end of function init_end  ----- */

 

void on_input (  )

{

        char c;

        while((c = getch()) != 'q'){

                if(c == 'w')

                mvaddch(20,20,'!');

                else if(c == 'e')

                mvaddch(20,20,'0');

                else if(c == 'r')

                mvaddch(20,20,'t');

        }

}              /* -----  end of function on_input  ----- */

 

void do_main (  )

{

        while(1){

                move(50,50);

                addstr("do other thing");

        }

 

}              /* -----  end of function do_main  ----- */


    从这个例子可以发现do_main没有执行,因为on_input一直等待用户输入阻塞了下面的程序运行。所以在有些场景像getchar或者getch这类的阻塞函数无法满足一些需求,那么就需要使用异步IO。异步IO的实现有两种方法:

    1.设置输入O_ASYNC位


    2.使用aio_read()

相关推荐