首先看这样一段代码
#include<stdio.h>
int main()
{
char s1[5],s2[7];
scanf("%c%c",s1,s2);
printf("%c\n",s1[0]);
printf("%c",s2[0]);
return 0;
}
我们想到的可能是,分别输入两个字符再分别打印在屏幕上
但事实
很明显只输入了一次,也只输出了一次,
可能我们会觉得是两个%c一起写的问题,所以我们写出了以下代码
#include<stdio.h>
int main()
{
char s1[5],s2[7];
scanf("%c",s1);
scanf("%c",s2);
printf("%c\n",s1[0]);
printf("%c",s2[0]);
return 0;
}
结果和上面是一样的。还是只有一个结果。
但幸运的我们可能会手残一下,两次输入都是写的s1;
#include<stdio.h>
int main()
{
char s1[5],s2[7];
scanf("%c",s1);
scanf("%c",s1);
printf("%c\n",s1[0]);
printf("%c",s2[0]);
return 0;
}
这时我们会因祸得福的发现一点问题
没错,这次他啥也没有输出。就和上面的s2一样。
这下我们把目光放在了第二次输入上
这里不得不提一下 缓存区 这东西
缓存区
C语言中的缓冲区又称为缓存,它是内存空间的一部分。
也就是说,在内存空间中预留了一定的存储空间,这些存储空间用来缓冲输入或输出的数据,这部分预留的空间就叫做缓冲区。
C语缓冲区分为三种类型:1、全缓冲 2、行缓冲 3、不带缓冲。
缓冲区根据其对应的是输入设备还是输出设备,分为输入缓冲区和输出缓冲区。
例如,在我们平时要在磁盘中读取信息的情况下,先会把数据放到缓存区中,读取完后,再次从磁盘中读取信息。
缓存区,他的意义就是在高速CPU与低速的设备之间的一个区域,这个区域让CPU工作效率更高。
1) 全缓冲
当填满标准I/O缓存后才进行实际I/O操作。全缓冲的典型代表是对磁盘文件的读写。
2) 行缓冲
当在输入和输出中遇到换行符时,执行真正的I/O操作。这时,我们输入的字符先存放在缓冲区,等按下回车键换行时才进行实际的I/O操作。典型代表是标准输入(stdin)和标准输出(stdout)。
3) 不带缓冲
也就是不进行缓冲,标准出错情况stderr是典型代表,这使得出错信息可以直接尽快地显示出来。
大部分系统默认使用下列类型的缓存:
标准出错是不带缓存的。
如果是涉及终端设备的流,则它们是行缓存的,否则是全缓存的。
我们经常用到的输入输出流,在目前的ANSI C 中缓存的特征是:stdin和stdout是行缓存;而stderr是无缓存的。
简言之,就是我们输入的有两个东西 1个字符 +1个(回车)
回车停留在缓存区,第二次输入直接将回车输入进去了,
所以无法进行第二次输入。
怎样解决呢?
使用fflush()函数
fflush()函数冲洗流中的信息,该函数通常用于处理磁盘文件。
清除读写缓冲区,需要立即把输出缓冲区的数据进行物理写入时。
fflush()函数包含在stdio.h头文件中。
int fflush(FILE *stream),在这里的stream就是所要清除缓存区的文件。
因此我们把开始的程序稍作修改,加上fflush函数
#include<stdio.h>
int main()
{
char s1[5],s2[7];
scanf("%c",s1);
fflush(stdin);
scanf("%c",s2);
printf("%c\n",s1[0]);
printf("%c",s2[0]);
return 0;
}
这下再看运行结果
令人满意,问题解决了。
希望对大家有所帮助