清空键盘缓冲区很多种方法,如用 fflush(stdin); rewind(stdin); setbuf(stdin, NULL);前两者仅对windows有用,最后一个则对Linux系统也适用。那么为什么需要清空键盘缓冲区呢?

以下几个实例:

Sample one

01#include <stdio.h>
02
03int main(void)
04{
05char ch1;
06char ch2;
07
08ch1 = getchar();
09ch2 = getchar();
10printf("%d %d", ch1, ch2);
11return 0;
12}

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

【分析】:

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

【解决办法】:

清空缓冲区的残留数据。

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

修正后的写法:
Sample two

01 
05
06#include <stdio.h>
07
08int main()
09{
10char ch1;
11char ch2;
12
13scanf("%c", &ch1);
14printf("ch1 = %d", ch1);
15
16fflush(stdin);
17
18scanf("%c", &ch2);
19printf("ch2 = %d", ch2);
20return 0;
21}

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

Sample three

01 
07
08#include <stdio.h>
09
10int main()
11{
12char ch1;
13char ch2;
14
15scanf("%c", &ch1);
16printf("ch1 = %d", ch1);
17
18setbuf(stdin, NULL); 
19
20scanf("%c", &ch2);
21printf("ch2 = %d", ch2);
22return 0;
23}
Logo

更多推荐