C 清空键盘缓冲区若干方法
写这次的数据结构的作业的时候对于缓冲区问题深表蛋疼,getchar()深表拙计,于是搜了一下……
以下文字来自:http://www.ludou.org/c-clear-buffer-area.html
清空键盘缓冲区很多种方法,如用fflush(stdin); rewind(stdin);等,但是在linux这些都不起作用,还得我今天试了半天都没成功,上网搜了一下发现setbuf(stdin, NULL);就能直接清空键盘缓冲区了。
以下几个实例:
Sample one
1#include <stdio.h>
2
3int main()
4{
5 char ch1;
6 char ch2;
7
8 ch1 = getchar();
9 ch2 = getchar();
10 printf("%d %d", ch1, ch2);
11 return 0;
12}
13
程序的本意很简单,就是从键盘读入两个字符,然后打印出这两个字符的ASCII码值。可是执行程序后会发现出了问题:当从键盘输入一个字符后,就打印出了结果,根本就没有输入第二个字符程序就结束了。例如用户输入字符’a’, 打印结果是97,10。这是为什么呢?
【分析】:
scanf()和getchar()函数是从输入流缓冲区中读取值的,而并非从键盘(也就是终端)缓冲区读取。而读取时遇到回车(n)而结束的,这个n会一起读入输入流缓冲区的,所以第一次接受输入时取走字符后会留下字符n,这样第二次的读入函数直接从缓冲区中把n取走了,显然读取成功了,所以不会再从终端读取!其实这里的10恰好是回车符!这就是为什么这个程序只执行了一次输入操作就结束的原因!
【解决办法】:
清空缓冲区的残留数据。
使用 fflush(stdin); 或 rewind(stdin); 均可起到清空键盘缓冲区的作用,这两个函数均包含在stdio.h这个头文件中
修正后的写法: Sample two
1/*
2 * 本程序只适用于 Windows 系统,测试平台:
3 * Windows XP,Microsoft Visual C++ 6.0 SP6
4*/
5
6#include <stdio.h>
7
8int main()
9{
10 char ch1;
11 char ch2;
12
13 scanf("%c", &ch1);
14 printf("ch1 = %d", ch1);
15
16 fflush(stdin); /*清空缓冲区,也可以使用rewind(stdin);*/
17
18 scanf("%c", &ch2);
19 printf("ch2 = %d", ch2);
20 return 0;
21}
22
上面的实例只适用于Windows系统,在Linux环境下上面两种写法都是不起作用的,所以还要换个函数。
Sample three
1/*
2* 本程序适用于 Windows 和 Linux 系统,
3* 测试环境:
4* Windows XP,Microsoft Visual C++ 6.0 SP6
5* Ubuntu Linux 8.04, NetBeans IDE 6.7
6*/
7
8#include <stdio.h>
9
10int main()
11{
12 char ch1;
13 char ch2;
14
15 scanf("%c", &ch1);
16 printf("ch1 = %d", ch1);
17
18 setbuf(stdin, NULL); /*清空缓冲区*/
19
20 scanf("%c", &ch2);
21 printf("ch2 = %d", ch2);
22 return 0;
23}
24
评论 (0)