C语言编程—清空键盘缓冲区,Linux和Windows下完美实现

日期: 标签:C语言 8 条留言
如需帮忙改代码,或者WordPress二次开发、PHP网站建设等需求,可联系我购买付费服务:  点此联系我

     清空键盘缓冲区很多种方法,如用fflush(stdin); rewind(stdin);等,但是在linux这些都不起作用,还得我今天试了半天都没成功,上网搜了一下发现setbuf(stdin, NULL);就能直接清空键盘缓冲区了。

以下几个实例:

Sample one

#include <stdio.h>

int main()
{
    char ch1;
    char ch2;

    ch1 = getchar();
    ch2 = getchar();
    printf("%d  %d", ch1, ch2);
    return 0;
}

     程序的本意很简单,就是从键盘读入两个字符,然后打印出这两个字符的ASCII码值。可是执行程序后会发现出了问题:当从键盘输入一个字符后,就打印出了结果,根本就没有输入第二个字符程序就结束了。例如用户输入字符'a', 打印结果是97,10。这是为什么呢?

【分析】:

     scanf()和getchar()函数是从输入流缓冲区中读取值的,而并非从键盘(也就是终端)缓冲区读取。而读取时遇到回车(n)而结束的,这个n会一起读入输入流缓冲区的,所以第一次接受输入时取走字符后会留下字符n,这样第二次的读入函数直接从缓冲区中把n取走了,显然读取成功了,所以不会再从终端读取!其实这里的10恰好是回车符!这就是为什么这个程序只执行了一次输入操作就结束的原因!

【解决办法】:

     清空缓冲区的残留数据。

     使用 fflush(stdin); 或 rewind(stdin); 均可起到清空键盘缓冲区的作用,这两个函数均包含在stdio.h这个头文件中

修正后的写法:
Sample two

/*
 * 本程序只适用于 Windows 系统,测试平台:
 * Windows XP,Microsoft Visual C++ 6.0 SP6
*/

#include <stdio.h>

int main()
{
    char ch1;
    char ch2;

    scanf("%c", &ch1);
    printf("ch1 = %d", ch1);

    fflush(stdin);   /*清空缓冲区,也可以使用rewind(stdin);*/

    scanf("%c", &ch2);
    printf("ch2 = %d", ch2);
    return 0;
}

     上面的实例只适用于Windows系统,在Linux环境下上面两种写法都是不起作用的,所以还要换个函数。

Sample three

/*
* 本程序适用于 Windows 和 Linux 系统,
* 测试环境:
* Windows XP,Microsoft Visual C++ 6.0 SP6
* Ubuntu Linux 8.04, NetBeans IDE 6.7
*/

#include <stdio.h>

int main()
{
    char ch1;
    char ch2;

    scanf("%c", &ch1);
    printf("ch1 = %d", ch1);

    setbuf(stdin, NULL); /*清空缓冲区*/

    scanf("%c", &ch2);
    printf("ch2 = %d", ch2);
    return 0;
}

-- 完 --

本文采用 「CC BY-NC-SA 4.0」创作共享协议,转载请标注以下信息:
原文出处:露兜博客 https://www.ludou.org/c-clear-buffer-area.html
露兜
kaapass@outlook.com  QQ 825533758

业余编程爱好者,主业是淘宝店主,卖些工艺品,感兴趣可以到我的淘宝店看看(旺旺不提供技术咨询):西西弗sisyphe

8 条留言

点此留言
  1. 老饕

    虽然俺是计算机的,呵呵,可直接奔C++去了,c风格的代码没怎么写~~

  2. Ludou

    回复@老饕
    c++和c还是有很多共同的地方的。

  3. hemingway

    终于找到如何在C语言中清理内存缓存区了。

  4. 小泽

    @hemingway 怎么我测试的缓存里面的东西还是清空不了呢?

  5. asa

    fflush 在linux下只刷新输出流

  6. 小泽

    我是linux下的 使用setbuf(stdin, NULL);一开始接收到缓存里面的数据还是存在

  7. 狂想写作本

    非常感谢!

  8. Theodorus

    太感谢。。。。找到一个很好的解决方法!

发表留言