一段代码如下:
#include<stdio.h>
int main()
{
int a = 1, b = 2;
char c = 'k';
scanf("%d%d", &a, &b);
scanf("%c", &c);
}
在这里,如果第一个scanf()中不加/n,那么输入为12 21回车的话, 就将回车赋给了c.
原因在于从标准输入的是一种行缓存的方式,当输入回车的时候scanf()返回但是此时回车存在于缓冲区中,所以在下一次读的时候就将回车赋给了c变量.
所以要解决这种情况只需要将第一个scanf()改为scanf("%d%d/n");这样输入12 21 回车,之后再输入一个字符就赋给了变量c了.
但是如果使用了setbuf()又会怎么样呢?
将代码改为
#include<stdio.h>
int main()
{
int a = 1, b = 2;
char c = 'k';
scanf("%d%d", &a, &b);
setbuf(stdin, 0);
scanf("%c", &c);
}
在这里,如果第一个scanf()中加了/n的话,那么在输入了12 21 回车之后还要再输入一个字符才能运行到setbuf()这个函数.
原因是用换行符结尾时,scanf会跳过换行符去读下一个字符,所以必须再输入一个数才能退出这个scanf()函数.而由于此时输入的这个字符被setbuf()给清空了,所以在后面是看不到的.而上面第一个例子中scanf()跳过换行符去读下一个字符是读到了我们输入的字符,在第二个scanf()中将之赋给了c.而这一次虽然读到了字符,但是却会被setbuf()清空,所以不起作用.
此时要解决这个问题就只有在scanf()中去掉/n,这里为什么去掉/n后不会出现将回车赋给c的情况呢?原因在于setbuf()将
输入流给清空,所以也会将回车给清空,所以在下一个scanf()中会再一次输入一个字符来赋给c这个变量.