作者:fbysss
关键字:getch
问题1:标准c中没有getch函数,等待键盘输入之后,总是需要按下回车才能得到值,如何解决?
问题2:在等待键盘输入的时候,程序被阻塞了,下面的代码必须在输入处理之后才能执行。如果不使用线程,如何实现非阻塞模式?
解决办法:


#include  
  < 
  curses.h 
  > 
  
#include  
  < 
  fcntl.h 
  > 
  
 
  int 
   main()
 
  ... 
  {
    int ch;

    WINDOW * win=  initscr();              /**//* 开始curses模式  */
    scrollok(win,TRUE);                        /**//*设置屏幕可滚动,否则超出一屏之后显示不完全*/
     //raw();                              /* 禁用行缓冲   */
    keypad(stdscr, TRUE);               /**//* 开启功能键响应模式 */
    noecho();                           /**//* 当执行getch()函数的时候关闭键盘回显 */
    //fcntl(0,F_SETFL, O_NONBLOCK);//这句用于设置非阻塞模式。即在侦测键盘输入的同时,不影响getch后面语句的执行。本函数位于头文件fcntl.h中
    while(1)...{
    printw("Type any character to see it in bold ");

    ch = getch();                       /**//* 原注:如果没有调用raw()函数,必须按下enter键才可以执行下面的程序 
    实验结果表明,使用了raw()之后同样不需要回车就可以执行下去。另外,如果使用了raw(),ctrl+c也会被捕获*/

    if(ch == KEY_F(1))                  /**//* 如果没有调用keypad()初始化,将不会执行这条语句 */
    ...{
    printw("F1 Key pressed");       /**//* 如果没有使用 noecho() 函数,一些难看的控制字符将会被打印到屏幕上 */
    }
    else if(ch!=-1)
    ...{
    printw("The pressed key is ");
      attron(A_BOLD);
      printw("char:%c,intvalue:%d", ch,ch);
      attroff(A_BOLD);
    }
    refresh();                         /**//* 将缓冲区的内容打印到显示器上 */
}


     endwin();                            /**//* 结束curses模式     */
     return 0;
}

Linux下非阻塞getch实现示例_gcc


注:用gcc编译的时候要注意一点,必须加上-lcurses参数,否则会出现undefined reference to `initscr'等等一大堆错误信息