Linux C编程 使用scanf时清除键盘缓冲区 -- 清除输入缓存

Linux C编程 使用scanf时清除键盘缓冲区 -- 清除输入缓存
清空键盘缓冲区很多种方法,如用fflush(stdin); rewind(stdin);等,但是在linux这些都不起作用,还得我今天试了半天都没成功,上网搜了一下发现 setbuf(stdin, NULL);直接将标准输入改为不带缓存的IO。这样就根本消除了缓冲区的存在,不必担心scanf得到的结果收到前一次输入的影响 就能直接清空键盘缓冲区了。

以下几个实例:

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;

}

免责声明:本网信息来自于互联网,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。
相关文章
返回顶部